

# FEATURES:

- 8 Mbit LPC Firmware Memory SuperFlash device with integrated LPC Keyboard, System configuration, and Power Management controller
- ACPI 2.0 Compliant
- Conforms to LPC Interface Specification v1.1
  - Includes support for Multi-byte Firmware Memory Read/Write Cycles
    - Firmware Memory 1-, 2-, 4-, 16-, and 128-byte Read Cycles
    - Firmware Memory 1-, 2-, and 4-byte Write Cycles
  - 15.7 MB/sec data transfer rate @ 33MHz clock for Multi-Byte Read
  - One ID pin for LPC Firmware Memory Device selection

## • LPC Firmware Memory

- 8 Mbit Single Block of on-chip SuperFlash memory with two Shared-ROM modes
  - Mode 1: 7 Mbit (896 KByte) for system BIOS and 1 Mbit (128 KByte) for 8051 firmware
  - Mode 2: 7.5 Mbit (960 KByte) for system BIOS and 0.5 Mbit (64 KByte) for 8051 firmware
- Uniform 4 KByte Sectors and 64 KByte Blocks with Erase capability
- 19 Lockable Blocks: one 16 KByte Boot Block, two 8 KByte Parameter Blocks, one 32 KByte Parameter Block, fifteen 64 KByte Main Blocks
  - Block Locking Registers for individual block Read-Lock, Write-Lock, and Lock Down protection
- Lockable bottom 4 KByte sector for 8051 boot firmware
- Erase-Suspend allowing Read or Program of the other blocks

Two-Cycle Command Set

## Non-Volatile Registers (NVR)

- 64-bit SST Pre-Programmed Identifier
- 192-bit OTP User Unique Identifier with Write-Lock protection
- 3 KByte OTP User NVR area (UNVR)
- 4 KByte Erasable NVR area (ÈNVR) with Write-/ Read-Lock protection

## • Superior Reliability

- Endurance: 100,000 Cycles (typical)
- Greater than 100 years Data Retention

## • Fast Erase/Program Operations

- Sector-Erase Time: 55 ms (typical)
- Block-Erase Time: 55 ms (typical)
- Word-Program Time: 15 µs (typical)

## aLPC mode for Rapid Factory Programming

- Alternate LPC bus (aLPC) for in-system and factory programming
- Auto Address Increment (AAI)
- Multi-Byte Program
- Chip Rewrite Time: 12 seconds (typical)
- Embedded Enhanced 8051 MCU
  - 3- or 6-clock (selectable) per-instruction cycle
  - Up to 33 MHz 8051 operating frequency
  - Up to 128 KByte Program Address Space
  - 256 Byte standard 8051 RAM
  - 2 KByte on-chip expanded Data RAM / Executable RAM (Scratch ROM)
  - Extended up to 2 KByte Stack Space
  - Four Levels of Interrupt Priorities and Twelve Interrupt Vectors
  - Power-saving IDLE and Power-Down modes
  - Multiple Maskable Hardware Wake-up Events (sources include: Hibernation timer, LPC, serial interfaces, all GPIOs, and others)

## LPC Host Interfaces

- One 8042-style legacy KBC interface channel
- Two ACPI EC interface channels
- 32 8-bit LPC Host-to-8051 Mailbox Registers
- Programmable Base addresses for all channels
- System Interrupts
  - IRQ1 and IRQ12 via serialized IRQ Interface
  - Two EC SCI event outputs
  - SMI via Serialized IRQ2 or SMI event output
- Hardware GA20 and CPU Reset Outputs Control
- 16 x 8 (24 pins) Key Scan Matrix expandable to 16 x 14 (30 pins)
- Three Independent PS/2 Ports
  - Hardware driven receive and transmit protocols
    Integrated time-out control
- Two SMBus controllers/Three SMBus channels
  - SMBus 2.0 compliant
  - Master and Slave operation
  - Internal multiplexer for SMBus channel selection
- Full-Duplex Enhanced UART channel
- SPI Master/Slave channel





- Eight-channel ADC with 10-bit resolution
- Four-channel DAC with 8-bit resolution
- Two 8-bit Fan Tachometer channels with clock
   prescaler
- Three PWM channels with 8-bit resolution and independent prescaler
- Five direct LED control channels with blinking capability
- Watchdog Timer
- Hibernation Timer
- Three 16-bit Timers/Counters
- Configurable 5-Volt Tolerant General Purpose I/O Ports (GPIO)
  - 112 GPIOs with 35 dedicated (non-multiplexed with alternative function)
  - Any dedicated GPIO or GPIO with disabled alternative function can be configured as Edge-Trigger maskable Interrupt and/or Wake Up event

- Clocks
  - Standard 32.768 KHz crystal oscillator
  - 10 to 20MHz fail-safe internal ring oscillator (automatic switch-on if Power-Good signal is deasserted)
  - Up to 33MHz core clock derived directly from the external clock input or via internal PLL
- Single 3.0-3.6V operation with 5V tolerant I/O (except LPC bus and analog I/O)
- Low Power Consumption
  - Idle Mode supply current: 17mA (typical)
  - Power-Down mode supply current: 100 µA (typical)
- Temperature Range: 0°C to 70°C
- Packages Available
  - 176-lead LQFP
  - 176-ball TFBGA
- All non-Pb (lead-free) devices are RoHS Compliant

# **PRODUCT DESCRIPTION**

The SST79LF008 is a high-performance LPC flash device with integrated PC Keyboard/Auxiliary device controller (KBC) and ACPI embedded controller (EC). This product is well suited for a wide range of mobile internet computing applications which require high integration (small form factor), superior power, and thermal management capability.

SST79LF008 includes 8Mbit of SuperFlash memory, which can be used to store system BIOS as well as KBC/EC firmware. Either 128 KByte (1 Mbit) or 64 KByte (0.5 Mbit) of the SuperFlash memory can be allocated for the KBC/EC code providing, respectively, 896 KByte (7.0 Mbit) or 960 KByte (7.5 Mbit) for the system BIOS memory. The SST79LF008 features in-system programming, which provides maximum flexibility in the manufacturing environment as well as a mechanism for updating the keyboard firmware code, the main system BIOS code, and adding new functionality in the end-user environment in order to meet the latest market demands. It also speeds up software development and improves the overall time-to-market. The SST79LF008 is manufactured with SST's proprietary, high-performance SuperFlash technology. The split-gate cell design and thick-oxide tunneling injector attain better reliability and manufacturing capability compared with alternate approaches. The device significantly improves performance and reliability, while lowering the power consumption.

The SST79LF008 is designed to be compatible with any LPC bus compatible host controllers, such as the ICHx or other south-bridge devices of PC chipsets for PC-BIOS application. It provides several mechanisms controlled by KBC/EC firmware and/or LPC host for code and data storage protection. SST79LF008 also includes an additional 4 Kbyte of lockable, open-after-reset SuperFlash memory, which can be used as secure ENVR storage.

SST79LF008 on-chip peripherals, including PS/2 ports, Matrix scanner, SMBus controllers, and ADC/DAC/PWM with flexible GPIO configuration, provide necessary hardware support for the KBC/EC functions on the mobile PC platforms.



# **TABLE OF CONTENTS**

| 1.0 | FUNCTIONAL BLOCKS                                                                               | 15 |
|-----|-------------------------------------------------------------------------------------------------|----|
| 2.0 | PIN ASSIGNMENTS.                                                                                | 16 |
|     | 2.1 Pin Descriptions                                                                            | 18 |
|     | 2.2 I/O Type Descriptions.                                                                      |    |
| 20  | MEMORY ORGANIZATION                                                                             |    |
| 5.0 |                                                                                                 |    |
|     | 3.1 Program Memory                                                                              |    |
|     | 3.2 Data Memory                                                                                 |    |
|     | 3.3 Data Memory Addressing Modes.                                                               |    |
|     | 3.4 Special Function Registers (SFRs)                                                           |    |
|     | 3.4.1 SFR Map                                                                                   |    |
|     | 3.4.2 SFR References.                                                                           |    |
|     | 3.5 Memory Mapped Configuration Registers (MMCR)                                                |    |
|     | 3.5.1 MMCR References.                                                                          |    |
|     | 3.5.2 JEDEC Registers                                                                           | 42 |
| 4.0 | FLASH MEMORY PROGRAMMING                                                                        | 43 |
|     | 4.1 SuperFlash Memory Overview                                                                  | 43 |
|     | 4.2 Flash Memory Map                                                                            | 44 |
|     | 4.2.1 ENVR / UNVR Address Space                                                                 | 44 |
|     | 4.2.2 Programming Modes                                                                         | 44 |
|     | 4.3 Shared ROM Interface                                                                        | 45 |
|     | 4.4 In-Application Programming Mode                                                             | 46 |
|     | 4.4.1 Scratch ROM Mapping Control                                                               | 46 |
|     | 4.4.2 IAP Mode Control                                                                          |    |
|     | 4.4.3 Address Selection for IAP Commands                                                        |    |
|     | 4.4.4 IAP Mode Commands Description                                                             |    |
|     | 4.4.4.1 No Operation                                                                            |    |
|     | 4.4.4.3 Block-Erase                                                                             |    |
|     | 4.4.4.4 Word-Program.                                                                           |    |
|     | 4.4.4.5 Erase-Suspend                                                                           |    |
|     | 4.4.4.6 Erase-Resume                                                                            | -  |
|     | 4.4.4.7 Word-Read                                                                               |    |
|     | 4.5 BootRom Area                                                                                |    |
|     | 4.6 LPC Flash Programming Mode                                                                  |    |
|     | 4.0 EFC Plash Programming Mode                                                                  |    |
|     | •                                                                                               |    |
|     | 4.8 aLPC MODE                                                                                   |    |
|     | 4.8.1       Alternate LPC (aLPC) Interface         4.8.2       aLPC Access to BIOS and KBC Code |    |
|     | 4.8.3 aLPC Memory Write Operation with Auto-Address Increment and Multi-Byte Programming        |    |
|     | 4.8.4 aLPC Memory Read Operation                                                                |    |



| Adva | Ince Information                                      |    |
|------|-------------------------------------------------------|----|
|      | 4.8.5 aLPC I/O Write Operation                        | 62 |
|      | 4.8.6 aLPC Flash Commands                             |    |
|      |                                                       |    |
| 5.0  | POWER, RESET AND CLOCK SOURCES                        | 66 |
|      | 5.1 Power Planes                                      | 66 |
|      | 5.2 Reset Sources                                     | 66 |
|      | 5.2.1 Power-On Reset.                                 | 68 |
|      | 5.2.2 External Reset                                  | 69 |
|      | 5.2.3 Brown-out Detection Reset                       | 69 |
|      | 5.2.4 Watchdog Timer (WDT) Reset                      |    |
|      | 5.2.5 aLPC Soft Reset                                 |    |
|      | 5.2.6 LPC Soft Reset                                  |    |
|      | 5.2.7 8051 Firmware Soft Reset                        |    |
|      | 5.2.8 Configuration Soft Reset                        |    |
|      | 5.2.9 LPC Interface Reset.                            |    |
|      | 5.3 Clock Sources                                     |    |
|      | 5.3.1 Clock Input Options                             |    |
|      | 5.3.1.1 Crystal Oscillator                            |    |
|      | 5.3.2 Clock Selection Control and Clock Domains       |    |
|      | 5.3.3 Clock Switching after Power On and Reset        |    |
|      | 5.3.4 Clock Switching in Low Power Modes              |    |
|      |                                                       |    |
| 6.0  | 8051 EMBEDDED MICROCONTROLLER                         | 77 |
|      | 6.1 8051 MCU Enhancement.                             | 77 |
|      | 6.2 8051 Addressing Modes                             | 77 |
|      | 6.2.1 16-Bit Addressing Mode                          |    |
|      | 6.2.2 17-Bit Contiguous Addressing Mode               |    |
|      | 6.2.2.1 8051 Instruction Set Modifications            |    |
|      | 6.3 8051 Machine Cycle Control                        | 79 |
|      | 6.4 8051 Dual Data Pointers                           |    |
|      | 6.5 8051 Stack Extension                              |    |
|      |                                                       | 00 |
| 7.0  | LPC INTERFACE                                         | 82 |
|      | 7.1 LPC Bus Transfer.                                 | 82 |
|      | 7.2 LPC Bus Cycles                                    | 82 |
|      | 7.2.1 Firmware Memory Cycles.                         |    |
|      | 7.2.2 LPC Memory Cycles                               |    |
|      | 7.2.3 LPC I/O Cycles                                  |    |
|      | 7.3 LPC Flash Command Definitions                     | 89 |
|      | 7.3.1 Read Array Command                              |    |
|      | 7.3.2 Read Device Identifier Command                  |    |
|      | 7.3.3 Read Status Register Command                    |    |
|      | 7.3.4 Clear Status Register Command                   |    |
|      | 7.3.5 Sector Erase Command and Block Erase Command    |    |
|      | 7.3.6 Program Command                                 |    |
|      | 7.3.7 Erase Suspend Command and Erase Resume Commands | 91 |



|      | 7.3.8 User Unique ID Read, Program and Lockout Commands                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | . 92                                                                                                                                                                                |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 7.3.10 Force / Release LPC Soft Reset Commands                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                     |
|      | 7.4 LPC Abort Mechanism and Invalid Fields                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                     |
|      | 7.4.1 Response to Invalid Fields for Firmware Memory Cycle         7.4.2 Response to Invalid Fields for LPC Memory Cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                     |
|      | 7.5 Multiple Device Selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                     |
|      | 7.5.1 Multiple Device Selection for Firmware Memory Cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                     |
|      | 7.5.2 Multiple Device Selection for LPC Memory Cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                     |
|      | 7.6 LPC Memory Mapped Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                     |
|      | 7.6.1 Flash Memory Block Locking Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                     |
|      | 7.6.2 JEDEC ID Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                     |
|      | 7.6.3 Multi-byte Read/Write Configuration Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                     |
|      | 7.6.4 Unique ID Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                     |
|      | 7.7 PCI CLOCK RUN CONTROL SUPPORT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                     |
|      | 7.8 LPC Power Down Protocol Support                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | . 97                                                                                                                                                                                |
| 8.0  | INTERRUPTS AND WAKEUPS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | . 98                                                                                                                                                                                |
|      | 8.1 SST79LF008 Interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                     |
|      | 8.2 SST79LF008 Wakeups                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                     |
|      | 8.3 INTERRUPT CONTROL REGISTERS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                     |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 101                                                                                                                                                                                 |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 102                                                                                                                                                                                 |
| 9.0  | GPIO PORTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 123                                                                                                                                                                                 |
| 9.0  | 9.1 GPIO CONTROL REGISTERS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                     |
|      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 123                                                                                                                                                                                 |
|      | 9.1 GPIO CONTROL REGISTERS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 123<br>141                                                                                                                                                                          |
|      | 9.1 GPIO CONTROL REGISTERS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 123<br>141<br>141                                                                                                                                                                   |
|      | 9.1 GPIO CONTROL REGISTERS         TIMERS/COUNTERS, WATCHDOG TIMER AND PWM         10.1 Timers: T0, T1, T2                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 123<br>141<br>141<br>141                                                                                                                                                            |
|      | 9.1 GPIO CONTROL REGISTERS<br>TIMERS/COUNTERS, WATCHDOG TIMER AND PWM<br>10.1 Timers: T0, T1, T2<br>10.2 Timer Operations<br>10.2.1 Timer 1 and Timer 0<br>10.2.1.1 Mode 0                                                                                                                                                                                                                                                                                                                                                                                                | 123<br>141<br>141<br>141<br>141<br>141                                                                                                                                              |
|      | 9.1 GPIO CONTROL REGISTERS<br>TIMERS/COUNTERS, WATCHDOG TIMER AND PWM<br>10.1 Timers: T0, T1, T2<br>10.2 Timer Operations<br>10.2.1 Timer 1 and Timer 0<br>10.2.1.1 Mode 0<br>10.2.1.2 Mode 1                                                                                                                                                                                                                                                                                                                                                                             | 123<br>141<br>141<br>141<br>141<br>141<br>141                                                                                                                                       |
|      | 9.1 GPIO CONTROL REGISTERS<br>TIMERS/COUNTERS, WATCHDOG TIMER AND PWM<br>10.1 Timers: T0, T1, T2<br>10.2 Timer Operations<br>10.2.1 Timer 1 and Timer 0<br>10.2.1.1 Mode 0                                                                                                                                                                                                                                                                                                                                                                                                | 123<br>141<br>141<br>141<br>141<br>141<br>141<br>141                                                                                                                                |
|      | 9.1 GPIO CONTROL REGISTERS<br>TIMERS/COUNTERS, WATCHDOG TIMER AND PWM<br>10.1 Timers: T0, T1, T2<br>10.2 Timer Operations<br>10.2.1 Timer 1 and Timer 0<br>10.2.1.1 Mode 0<br>10.2.1.2 Mode 1<br>10.2.1.3 Mode 2<br>10.2.1.4 Mode 3<br>10.2.2 Timer 2                                                                                                                                                                                                                                                                                                                     | 123<br>141<br>141<br>141<br>141<br>141<br>141<br>141<br>141<br>142                                                                                                                  |
|      | 9.1 GPIO CONTROL REGISTERS<br>TIMERS/COUNTERS, WATCHDOG TIMER AND PWM<br>10.1 Timers: T0, T1, T2<br>10.2 Timer Operations<br>10.2.1 Timer 1 and Timer 0<br>10.2.1.1 Mode 0<br>10.2.1.2 Mode 1<br>10.2.1.3 Mode 2<br>10.2.1.4 Mode 3<br>10.2.2 Timer 2<br>10.2.2.1 16-bit Timer/Counter Capture Mode                                                                                                                                                                                                                                                                       | <ol> <li>123</li> <li>141</li> <li>141</li> <li>141</li> <li>141</li> <li>141</li> <li>141</li> <li>141</li> <li>142</li> <li>142</li> </ol>                                        |
|      | 9.1 GPIO CONTROL REGISTERS         TIMERS/COUNTERS, WATCHDOG TIMER AND PWM         10.1 Timers: T0, T1, T2         10.2 Timer Operations         10.2.1 Timer 1 and Timer 0         10.2.1.1 Mode 0         10.2.1.2 Mode 1         10.2.1.3 Mode 2         10.2.1.4 Mode 3         10.2.2 Timer 2         10.2.2.1 16-bit Timer/Counter Capture Mode         10.2.2.2 16-bit Timer/Counter Auto-reload Mode                                                                                                                                                              | <ol> <li>123</li> <li>141</li> <li>141</li> <li>141</li> <li>141</li> <li>141</li> <li>141</li> <li>141</li> <li>142</li> <li>142</li> <li>142</li> <li>142</li> <li>142</li> </ol> |
|      | 9.1 GPIO CONTROL REGISTERS<br>TIMERS/COUNTERS, WATCHDOG TIMER AND PWM<br>10.1 Timers: T0, T1, T2<br>10.2 Timer Operations<br>10.2.1 Timer 1 and Timer 0<br>10.2.1.1 Mode 0<br>10.2.1.2 Mode 1<br>10.2.1.3 Mode 2<br>10.2.1.4 Mode 3<br>10.2.2 Timer 2<br>10.2.2.1 16-bit Timer/Counter Capture Mode<br>10.2.2.2 16-bit Timer/Counter Auto-reload Mode<br>10.2.2.3 Baud Rate Generator Mode                                                                                                                                                                                | 123<br>141<br>141<br>141<br>141<br>141<br>141<br>141<br>142<br>142<br>142                                                                                                           |
|      | 9.1 GPIO CONTROL REGISTERS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 123<br>141<br>141<br>141<br>141<br>141<br>141<br>142<br>142<br>142<br>142                                                                                                           |
|      | 9.1 GPIO CONTROL REGISTERS .<br>TIMERS/COUNTERS, WATCHDOG TIMER AND PWM .<br>10.1 Timers: T0, T1, T2 .<br>10.2 Timer Operations .<br>10.2.1 Timer 1 and Timer 0.<br>10.2.1.1 Mode 0 .<br>10.2.1.2 Mode 1 .<br>10.2.1.3 Mode 2 .<br>10.2.1.4 Mode 3 .<br>10.2.2 Timer 2.<br>10.2.2.1 16-bit Timer/Counter Capture Mode .<br>10.2.2.2 I6-bit Timer/Counter Auto-reload Mode .<br>10.2.2.3 Baud Rate Generator Mode .<br>10.3 Timers/Counter SFRs.<br>10.4 Watchdog Timer (WDT) .                                                                                            | 123<br>141<br>141<br>141<br>141<br>141<br>141<br>142<br>142<br>142<br>142                                                                                                           |
|      | 9.1 GPIO CONTROL REGISTERS<br>TIMERS/COUNTERS, WATCHDOG TIMER AND PWM<br>10.1 Timers: T0, T1, T2<br>10.2 Timer Operations.<br>10.2.1 Timer 1 and Timer 0.<br>10.2.1.1 Mode 0<br>10.2.1.2 Mode 1<br>10.2.1.2 Mode 1<br>10.2.1.3 Mode 2<br>10.2.1.4 Mode 3<br>10.2.2 Timer 2.<br>10.2.2.1 16-bit Timer/Counter Capture Mode<br>10.2.2.2 16-bit Timer/Counter Auto-reload Mode<br>10.2.2.3 Baud Rate Generator Mode<br>10.3 Timers/Counters SFRs.<br>10.4 Watchdog Timer (WDT).<br>10.4.1 Watchdog Timer MMCRs.                                                              | 123<br>141<br>141<br>141<br>141<br>141<br>141<br>142<br>142<br>142<br>142                                                                                                           |
|      | 9.1 GPIO CONTROL REGISTERS .<br>TIMERS/COUNTERS, WATCHDOG TIMER AND PWM .<br>10.1 Timers: T0, T1, T2 .<br>10.2 Timer Operations .<br>10.2.1 Timer 1 and Timer 0 .<br>10.2.1.1 Mode 0 .<br>10.2.1.2 Mode 1 .<br>10.2.1.3 Mode 2 .<br>10.2.1.4 Mode 3 .<br>10.2.2 Timer 2 .<br>10.2.2 1 16-bit Timer/Counter Capture Mode .<br>10.2.2 1 16-bit Timer/Counter Auto-reload Mode .<br>10.2.2.3 Baud Rate Generator Mode .<br>10.3 Timers/Counters SFRs.<br>10.4 Watchdog Timer (WDT) .<br>10.4.1 Watchdog Timer MMCRs.<br>10.5 Hibernation Timer .                             | 123<br>141<br>141<br>141<br>141<br>141<br>141<br>142<br>142<br>142<br>142                                                                                                           |
|      | 9.1 GPIO CONTROL REGISTERS<br>TIMERS/COUNTERS, WATCHDOG TIMER AND PWM<br>10.1 Timers: T0, T1, T2<br>10.2 Timer Operations.<br>10.2.1 Timer 1 and Timer 0.<br>10.2.1.1 Mode 0<br>10.2.1.2 Mode 1<br>10.2.1.2 Mode 1<br>10.2.1.3 Mode 2<br>10.2.1.4 Mode 3<br>10.2.2 Timer 2.<br>10.2.2.1 16-bit Timer/Counter Capture Mode<br>10.2.2.2 16-bit Timer/Counter Auto-reload Mode<br>10.2.2.3 Baud Rate Generator Mode<br>10.3 Timers/Counters SFRs.<br>10.4 Watchdog Timer (WDT).<br>10.4.1 Watchdog Timer MMCRs.                                                              | 123<br>141<br>141<br>141<br>141<br>141<br>141<br>142<br>142<br>142<br>142                                                                                                           |
| 10.0 | 9.1 GPIO CONTROL REGISTERS<br>TIMERS/COUNTERS, WATCHDOG TIMER AND PWM<br>10.1 Timers: T0, T1, T2<br>10.2 Timer Operations<br>10.2.1 Timer 1 and Timer 0<br>10.2.1.1 Mode 0<br>10.2.1.2 Mode 1<br>10.2.1.3 Mode 2<br>10.2.1.4 Mode 3<br>10.2.2 Timer 2<br>10.2.2.1 16-bit Timer/Counter Capture Mode<br>10.2.2.2 16-bit Timer/Counter Auto-reload Mode<br>10.2.2.3 Baud Rate Generator Mode<br>10.3 Timers/Counters SFRs.<br>10.4 Watchdog Timer (WDT)<br>10.4.1 Watchdog Timer MMCRs<br>10.5 Hibernation Timer.<br>10.6 Pulse Width Modulators (PWM)<br>10.6.1 PWM MMCRs. | 123<br>141<br>141<br>141<br>141<br>141<br>141<br>141<br>142<br>142<br>142                                                                                                           |
| 10.0 | 9.1 GPIO CONTROL REGISTERS .<br>TIMERS/COUNTERS, WATCHDOG TIMER AND PWM .<br>10.1 Timers: T0, T1, T2 .<br>10.2 Timer Operations .<br>10.2.1 Timer 1 and Timer 0.<br>10.2.1.1 Mode 0 .<br>10.2.1.2 Mode 1 .<br>10.2.1.2 Mode 1 .<br>10.2.1.3 Mode 2 .<br>10.2.2 Timer 2 .<br>10.2.2 Timer 2 .<br>10.2.2.2 16-bit Timer/Counter Capture Mode .<br>10.2.2.3 Baud Rate Generator Mode .<br>10.3 Timers/Counters SFRs.<br>10.4 Watchdog Timer (WDT) .<br>10.4.1 Watchdog Timer MMCRs .<br>10.5 Hibernation Timer.<br>10.6 Pulse Width Modulators (PWM) .                       | 123<br>141<br>141<br>141<br>141<br>141<br>141<br>142<br>142<br>142<br>142                                                                                                           |



| Advance Information                                               |       |  |
|-------------------------------------------------------------------|-------|--|
| 11.2 Framing Error Detection                                      | . 154 |  |
| 11.3 Automatic Address Recognition                                | . 155 |  |
| 11.3.1 Using the Given Address to Select Slaves                   | . 155 |  |
| 11.3.2 Using the Broadcast Address to Select Slaves               |       |  |
| 11.4 UART SFRs                                                    | . 157 |  |
| 12.0 SERIAL PERIPHERAL INTERFACE (SPI)                            | . 159 |  |
| 12.1 SPI Features                                                 | . 159 |  |
| 12.2 SPI Description                                              |       |  |
| 12.3 SPI Transfer Formats.                                        | . 160 |  |
| 12.4 SPI SFRs                                                     | . 161 |  |
| 13.0 SMBUS INTERFACE                                              | . 163 |  |
| 13.1 SMBus Features                                               |       |  |
| 13.2 SMBus Channels                                               |       |  |
| 13.3 SMBus Protocol Overview                                      |       |  |
| 13.4 SMBus MMCRs                                                  |       |  |
| 13.5 SMBus Multi-master Control and Status Registers              |       |  |
| 13.6 Multi-master Bus Address and Data Shift Registers            | . 169 |  |
| 13.7 SMBus Switch Control and Line Status Registers               | . 171 |  |
| 13.8 SMBus Operations                                             | . 171 |  |
| 13.8.1 Master Transmit Mode                                       |       |  |
| 13.8.2 Master Receive Mode                                        |       |  |
| 13.8.3 Slave Transmit Mode                                        |       |  |
| 13.8.5 Switching Between Master Transmit and Master Receive Modes |       |  |
|                                                                   |       |  |
| 14.0 PS/2 INTERFACE                                               | . 181 |  |
| 14.1 PS/2 Features                                                | . 181 |  |
| 14.2 PS/2 Channels                                                | -     |  |
| 14.3 PS/2 Protocol Overview                                       |       |  |
| 14.4 PS/2 MMCRs                                                   |       |  |
| 14.4.1 PS/2 Transmit Registers                                    |       |  |
| 14.4.2 PS/2 Receive Registers                                     |       |  |
| 14.4.4 PS/2 Status Registers                                      |       |  |
| 14.4.5 PS/2 Time-out and Status 2 Registers                       |       |  |
| 15.0 FAN TACHOMETERS                                              | . 191 |  |
| 15.1 Fan Tachometer Features                                      | . 191 |  |
| 15.2 Fan Tachometer Operation                                     |       |  |
| 15.3 Fan Tachometers MMCRs                                        |       |  |
| 16.0 ANALOG TO DIGITAL CONVERTER (ADC)                            | . 194 |  |
| 16.1 ADC Features                                                 |       |  |



|      | 16.2 ADC MMCRs                                                                     | 195 |
|------|------------------------------------------------------------------------------------|-----|
|      | 16.3 ADC Operations                                                                | 197 |
|      | 16.3.1 Single Mode                                                                 | 198 |
|      | 16.3.2 Continuous Mode                                                             | 199 |
| 17.0 | DIGITAL TO ANALOG CONVERTOR (DAC)                                                  | 201 |
|      | 17.1 DAC Features                                                                  | 201 |
|      | 17.2 DAC MMCRs                                                                     | 202 |
|      | 17.3 DAC Operations                                                                |     |
|      | 17.3.1 Output Voltage                                                              |     |
|      | 17.3.2 Conversion Cycle                                                            |     |
|      | 17.3.3 DAC Channel Control                                                         |     |
|      |                                                                                    |     |
| 18.0 | KEYBOARD CONTROLLER HOST INTERFACE                                                 |     |
|      | 18.1 Keyboard Controller Interface Overview                                        |     |
|      | 18.2 Keyboard Controller Interface MMCRs         18.3 Keyboard Matrix Scan Control |     |
|      |                                                                                    |     |
| 19.0 | GA20 AND CPU RESET HARDWARE CONTROL                                                |     |
|      | 19.1 GA20 State Machine                                                            |     |
|      | 19.2 GA20 and KBRST# MMCRs                                                         | 211 |
| 20.0 | ACPI EMBEDDED CONTROLLER INTERFACE                                                 | 213 |
|      | 20.1 ACPI Embedded Controller Interface Overview                                   |     |
|      | 20.2 Embedded Controller Interface MMCRs                                           |     |
|      | 20.3 SMI and SCI Control                                                           | 217 |
| 21.0 | MAILBOX INTERFACE AND DATA TRANSFER BLOCK                                          | 220 |
|      | 21.1 Mailbox Command/Data Transfer Registers                                       | 220 |
|      | 21.2 Mailbox Control Registers                                                     | 222 |
| 22.0 | SERIALIZED INTERRUPTS                                                              | 224 |
|      | 22.1 Serialized IRQ Cycle Overview                                                 | 224 |
|      | 22.2 Serialized IRQ Start Frame                                                    | 224 |
|      | 22.3 Serialized IRQ Data Frame                                                     | 225 |
|      | 22.4 Serialized IRQ Stop Frame                                                     | 225 |
| 23.0 | SST79LF008 CONFIGURATION                                                           | 226 |
|      | 23.1 Access to Configuration Registers                                             | 226 |
|      | 23.2 Configuration Registers Description.                                          | 228 |
| 24.0 | ELECTRICAL SPECIFICATION                                                           | 230 |
|      | 24.1 Absolute Maximum Stress Ratings                                               | 230 |
|      | 24.2 Operating Conditions                                                          |     |



|      | 24.3 DC Electrical Characteristics               | 231 |
|------|--------------------------------------------------|-----|
|      | 24.4 AC Electrical Characteristics               | 234 |
|      | 24.4.1 LPC Interface and Firmware Memory Timing. | 234 |
|      | 24.4.2 External Clocks and Reset Timing          | 238 |
|      | 24.4.3 SMBus Interface Timing                    | 239 |
|      | 24.4.4 PS/2 Interface Timing                     | 240 |
|      | 24.4.5 UART Timing                               | 243 |
|      | 24.4.6 SPI Timing                                | 244 |
|      | 24.4.7 PWM and FAN Tachometer Timing             | 247 |
|      | 24.4.8 aLPC Interface Timing                     | 248 |
|      | 24.5 Analog Characteristics                      | 249 |
|      | 24.5.1 ADC Characteristics                       | 249 |
|      | 24.5.2 DAC Characteristics                       | 249 |
| 25.0 | PRODUCT ORDERING INFORMATION                     | 250 |
|      | 25.1 Valid Combinations                          | 250 |
| 26.0 | PACKAGING DIAGRAMS                               | 251 |



# **LIST OF FIGURES**

| FIGURE 1-1: SST79LF008 Functional Block Diagram                                   |
|-----------------------------------------------------------------------------------|
| FIGURE 2-1: Pin Assignments for 176-ball TFBGA 16                                 |
| FIGURE 2-2: Pin Assignments for 176-lead LQFP 17                                  |
| FIGURE 3-1: SST79LF008 Program Memory Organization                                |
| FIGURE 3-2: 2 KByte Scratch ROM Mapping                                           |
| FIGURE 3-3: 1 KByte Scratch ROM Mapping 26                                        |
| FIGURE 3-4: 512 Byte Scratch ROM Mapping 27                                       |
| FIGURE 3-5: 256 Byte Scratch ROM Mapping 27                                       |
| FIGURE 3-6: SST79LF008 Data Memory Organization                                   |
| FIGURE 4-1: SST79LF008 Flash Memory Map 44                                        |
| FIGURE 4-2: Shared ROM Interface                                                  |
| FIGURE 4-3: IAP Sector-Erase                                                      |
| FIGURE 4-4: IAP Block-Erase                                                       |
| FIGURE 4-5: IAP Word-Program                                                      |
| FIGURE 4-6: IAP Word-Read                                                         |
| FIGURE 4-7: aLPC Logic Diagram                                                    |
| FIGURE 4-8: aLPC Snooper State Machine                                            |
| FIGURE 4-9: aLPC Memory Write Cycle 59                                            |
| FIGURE 4-10: aLPC Memory Read Cycle 61                                            |
| FIGURE 4-11: aLPC I/O Write Cycle (IDLE or READY state)                           |
| FIGURE 4-12: aLPC I/O Write cycle (SWITCHED state)                                |
| FIGURE 5-1: Reset Block Diagram                                                   |
| FIGURE 5-2: External Reset Circuit                                                |
| FIGURE 5-3: Crystal Oscillator Circuit                                            |
| FIGURE 5-4: SST79LF008 Clock Selection                                            |
| FIGURE 5-5: Power-On Sequence and Core Clock Switching                            |
| FIGURE 5-6: Clock Switching after Waking up from Power Down Mode                  |
| FIGURE 6-1: Dual Data Pointer Organization                                        |
| FIGURE 7-1: Firmware Memory Read Waveform                                         |
| FIGURE 7-2: Firmware Memory Write Waveform                                        |
| FIGURE 7-3: LPC Memory Read Cycle Waveform                                        |
| FIGURE 7-4: LPC Memory Write Cycle Waveform                                       |
| FIGURE 7-5: LPC I/O Read Cycle Waveform                                           |
| FIGURE 7-6: LPC I/O Write Cycle Waveform                                          |
| FIGURE 8-1: SST79LF008 Interrupt Structure (int1-int2)                            |
| FIGURE 8-2: SST79LF008 Interrupt Structure (int3) 100                             |
| FIGURE 8-3: SST79LF008 Interrupt Structure (int4) 101                             |
| FIGURE 8-4: SST79LF008 Interrupt Structure (int5) 102                             |
| FIGURE 8-5: SST79LF008 Interrupt Structure (int5, pd mode wakeup, 8051 interrupt) |
| FIGURE 10-1: Watchdog Timer                                                       |
| FIGURE 10-2: Hibernation Timer                                                    |



| FIGURE 11-1: Framing Error Block Diagram                          |
|-------------------------------------------------------------------|
| FIGURE 11-2: UART Timings in Mode 1                               |
| FIGURE 11-3: UART Timings in Modes 2 and 3                        |
| FIGURE 12-1: SPI Master-Slave Interconnection 159                 |
| FIGURE 12-2: SPI Transfer Format (CPHA = 0) 160                   |
| FIGURE 12-3: SPI Transfer Format (CPHA = 1) 160                   |
| FIGURE 13-1: SMBus Module Block Diagram                           |
| FIGURE 13-2: SMBus Relationship of SDAn to SCLn for Bit Transfer  |
| FIGURE 13-3: SMBus Byte Transfer                                  |
| FIGURE 13-4: SMBus Address Transfer                               |
| FIGURE 13-5: SMBus Master Transmit Mode Operation 172             |
| FIGURE 13-6: SMBus Master Receive Mode Operation 173              |
| FIGURE 13-7: SMBus Slave Transmit Mode Operation                  |
| FIGURE 13-8: SMBus Slave Receive Mode Operation 177               |
| FIGURE 13-9: SMBus Transmit/Receive Mode Switch                   |
| FIGURE 14-1: PS/2 Module Block Diagram 181                        |
| FIGURE 14-2: PS/2 Receive Protocol                                |
| FIGURE 14-3: PS/2 Transmit Protocol                               |
| FIGURE 15-1: Fan Tachometer Block Diagram 191                     |
| FIGURE 16-1: ADC Block Diagram 194                                |
| FIGURE 16-2: Example of ADC Operation (Single Mode) 198           |
| FIGURE 16-3: Example of ADC Operation (Continuous Mode) 200       |
| FIGURE 17-1: DAC Block Diagram                                    |
| FIGURE 18-1: KBC Interrupt Control 208                            |
| FIGURE 19-1: GA20 State Machine                                   |
| FIGURE 19-2: : Host and 8051 Control of GA20 212                  |
| FIGURE 20-1: SCI and SMI Generation Diagram 219                   |
| FIGURE 22-1: Serialized IRQ cycle                                 |
| FIGURE 24-1: AC Input/Output Reference Waveforms                  |
| FIGURE 24-2: A Test Load Example                                  |
| FIGURE 24-3: LCLK Wave Form                                       |
| FIGURE 24-4: LPC Output Timing Parameters                         |
| FIGURE 24-5: LPC Input Timing Parameters 236                      |
| FIGURE 24-6: LPC Reset Timing Diagram 237                         |
| FIGURE 24-7: External Input Clock Timing Diagram 238              |
| FIGURE 24-8: External Interrupt Timing Diagram 238                |
| FIGURE 24-9: Power Up and External Reset Timing Diagram           |
| FIGURE 24-10: SMBus Timing Diagram                                |
| FIGURE 24-11: PS/2 Hardware State Machine Receive Timing Diagram  |
| FIGURE 24-12: PS/2 Hardware State Machine Transmit Timing Diagram |
| FIGURE 24-13: PS/2 Interrupt Timing in bit-banging mode 243       |
| FIGURE 24-14: UART Timing Diagram (Shift Register Mode)           |
| FIGURE 24-15: SPI Master Timing Diagram (CPHA=0, MSTR = 1) 245    |



| FIGURE 24-16: SPI Master Timing Diagram (CPHA=1, MSTR = 1)            | 245 |
|-----------------------------------------------------------------------|-----|
| FIGURE 24-17: SPI Slave Timing Diagram (CPHA=0, MSTR = 0)             | 246 |
| FIGURE 24-18: SPI Slave Timing Diagram (CPHA=1, MSTR = 0)             | 246 |
| FIGURE 24-19: PWM Output Signals Timing Diagram                       | 247 |
| FIGURE 24-20: FAN Tachometer Input Timing Diagram                     | 248 |
| FIGURE 24-21: aLPC Timing Diagram                                     | 248 |
| FIGURE 26-1: 176-lead Low-profile Quad Flat Pack                      | 251 |
| FIGURE 26-2: 176-ball Thin-profile Fine-pitch Ball Grid Array (TFBGA) | 252 |



# LIST OF TABLES

| TABLE | 2-1: Pin Descriptions                             | 18 |
|-------|---------------------------------------------------|----|
| TABLE | 2-2: I/O Buffer Types                             | 24 |
| TABLE | 3-1: Special Function Register Memory Map         | 29 |
| TABLE | 3-2: Miscellaneous SFRs Reference                 | 30 |
| TABLE | 3-3: Timer SFRs Reference                         | 30 |
| TABLE | 3-4: UART SFRs References                         | 31 |
| TABLE | 3-5: SPI SFRs References                          | 31 |
|       | 3-6: GPIO Input MMCRs References                  |    |
|       | 3-7: GPIO Output MMCRs References                 |    |
| TABLE | 3-8: GPIO Direction MMCRs References              | 33 |
|       | 3-9: GPIO Function Selection MMCRs References     |    |
|       | 3-11: Interrupt Source MMCRs References           |    |
| TABLE | 3-10: GPIO Active Edge Selection MMCRs References | 35 |
| TABLE | 3-12: Wakeup Source MMCRs References              | 36 |
| TABLE | 3-13: Timer MMCRs References                      | 37 |
|       | 3-14: PWM MMCRs References                        |    |
|       | 3-15: SMBus MMCRs References                      |    |
| TABLE | 3-16: PS/2 MMCRs References.                      | 38 |
| TABLE | 3-17: Fan Tachometer MMCRs References             | 38 |
|       | 3-18: ADC MMCRs References                        |    |
|       | 3-19: DAC MMCRs References                        |    |
|       | 3-20: KBC Host Interface MMCRs References         |    |
| TABLE | 3-21: GA20 Control MMCRs References.              | 39 |
|       | 3-22: ACPI EC Interface MMCRs References          |    |
|       | 3-23: MailBox MMCRs References                    |    |
|       | 3-24: Configuration MMCRs References              |    |
|       | 3-25: Miscellaneous MMCRs References              |    |
|       | 4-1: ENVR Address Space                           |    |
|       | 4-2: UNVR Address Space                           |    |
|       | 4-3: Scratch ROM Mapping                          |    |
|       | 4-4: IAP Commands for SST79LF008                  |    |
|       | 4-5: OVERLAY Bit Value After RESET                |    |
| TABLE | 4-6: aLPC Snooper Command Sequences               | 55 |
|       | 4-7: aLPC Pin Descriptions                        |    |
|       | 4-8: aLPC Memory Write Cycle Field Definitions    |    |
| TABLE | 4-9: aLPC Memory Read Cycle Field Definitions.    | 60 |
|       | 4-10: aLPC I/O Write Cycle Field Definitions      |    |
|       | 4-11: aLPC Bus Flash Command Definitions          |    |
|       | 5-1: SST79LF008 Reset Sources                     |    |
|       | 5-2: SST79LF008 Clock Sources                     |    |
| TABLE | 5-3: Crystal Oscillator Circuit Components        | 71 |
|       |                                                   |    |



|                                                                               | 5-4: Clock Domains for SST79LF008 Modules                                                                                                                                                                                                                                                                                                                                                       | 72                                                                                                                                                                                          |
|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TABLE                                                                         | 6-1: 17-bit Addressing Mode-Specific Instructions                                                                                                                                                                                                                                                                                                                                               | 78                                                                                                                                                                                          |
| TABLE                                                                         | 7-1: Transfer Size Supported by the SST79LF008                                                                                                                                                                                                                                                                                                                                                  | 82                                                                                                                                                                                          |
| TABLE                                                                         | 7-2: Firmware and LPC Memory Cycles START Field Definition                                                                                                                                                                                                                                                                                                                                      | 82                                                                                                                                                                                          |
| TABLE                                                                         | 7-3: Firmware Memory Read Cycle Field Definitions.                                                                                                                                                                                                                                                                                                                                              | 83                                                                                                                                                                                          |
| TABLE                                                                         | 7-4: Firmware Memory Write Cycle Field Definitions.                                                                                                                                                                                                                                                                                                                                             | 84                                                                                                                                                                                          |
|                                                                               | 7-5: LPC Memory Read Cycle Field Definitions.                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                             |
| TABLE                                                                         | 7-6: LPC Memory Write Cycle Field Definitions.                                                                                                                                                                                                                                                                                                                                                  | 86                                                                                                                                                                                          |
|                                                                               | 7-7: LPC I/O Read Cycle Field Definitions.                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                             |
| TABLE                                                                         | 7-8: LPC I/O Write Cycle Field Definitions                                                                                                                                                                                                                                                                                                                                                      | 88                                                                                                                                                                                          |
|                                                                               | 7-9: LPC Flash Command Definitions1                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                             |
| TABLE                                                                         | 7-10: Product Identification                                                                                                                                                                                                                                                                                                                                                                    | 90                                                                                                                                                                                          |
| TABLE                                                                         | 7-11: Valid MSIZE Field for Firmware Memory Cycle                                                                                                                                                                                                                                                                                                                                               | 92                                                                                                                                                                                          |
| TABLE                                                                         | 7-12: Block Locking Registers                                                                                                                                                                                                                                                                                                                                                                   | 94                                                                                                                                                                                          |
|                                                                               | 7-13: Block Locking Register Bits                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                             |
|                                                                               | 7-14: JEDEC ID Registers                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                             |
|                                                                               | 7-15: Multi-byte Read/Write Configuration registers                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                             |
|                                                                               | 7-16: Unique ID Registers                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                             |
|                                                                               | 8-1: SST79LF008 Interrupt Sources                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                             |
|                                                                               | 9-1: LPC Host Status Signals as a Function of SSEL[2:0]                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                             |
|                                                                               | 9-2: GPIO96-GPIO111 Input/Output configuration control                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                             |
| TABLE                                                                         | 10-1: Timer 0 Operating Modes 1                                                                                                                                                                                                                                                                                                                                                                 | 41                                                                                                                                                                                          |
|                                                                               | 10-2: Timer 1 Operating Modes 1                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                             |
| TABLE                                                                         | 10-3: Timer 2 Operating Modes 1                                                                                                                                                                                                                                                                                                                                                                 | 42                                                                                                                                                                                          |
|                                                                               | 10-4: Timer/Counters SFRs 1                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                             |
| TABLE                                                                         | 10-5: Timer Operating Mode as a Function of Mode Bits                                                                                                                                                                                                                                                                                                                                           | 45                                                                                                                                                                                          |
|                                                                               | 10-6: LED 4/2/0 Behavior                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                             |
|                                                                               | 10-7: LED 3/1 Behavior                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                             |
| TABLE                                                                         | 11-1: Possible Addresses for Slaves 1 and 2 1                                                                                                                                                                                                                                                                                                                                                   | 56                                                                                                                                                                                          |
| TABLE                                                                         | 11-2: Possible Addresses for Slave 3 and Slave 2/3 Combination                                                                                                                                                                                                                                                                                                                                  | 56                                                                                                                                                                                          |
|                                                                               | 11-3: Serial Port Mode Description 1                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                             |
| IADLE                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                 | 58                                                                                                                                                                                          |
| TABLE                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                             |
| TABLE                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                 | 61                                                                                                                                                                                          |
| TABLE<br>TABLE                                                                | 12-1: SCK Rate as a Function of SPI Clock Rate Select Bits (Master Only) 1                                                                                                                                                                                                                                                                                                                      | 61<br>62                                                                                                                                                                                    |
| TABLE<br>TABLE<br>TABLE                                                       | 12-1:       SCK Rate as a Function of SPI Clock Rate Select Bits (Master Only)                                                                                                                                                                                                                                                                                                                  | 61<br>62<br>66                                                                                                                                                                              |
| TABLE<br>TABLE<br>TABLE<br>TABLE                                              | 12-1: SCK Rate as a Function of SPI Clock Rate Select Bits (Master Only)                                                                                                                                                                                                                                                                                                                        | 61<br>62<br>66<br>94                                                                                                                                                                        |
| TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE                                     | 12-1: SCK Rate as a Function of SPI Clock Rate Select Bits (Master Only).       1         12-2: SCK Rate as a Function of SPI Clock Rate Select Bits (Slave Only).       1         13-1: SMBus MMCRs       1         16-1: Analog Input Channels/Data Registers relationship       1                                                                                                            | 61<br>62<br>66<br>94<br>97                                                                                                                                                                  |
| TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE                            | 12-1: SCK Rate as a Function of SPI Clock Rate Select Bits (Master Only)                                                                                                                                                                                                                                                                                                                        | 61<br>62<br>94<br>97<br>205                                                                                                                                                                 |
| TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE                            | 12-1: SCK Rate as a Function of SPI Clock Rate Select Bits (Master Only)112-2: SCK Rate as a Function of SPI Clock Rate Select Bits (Slave Only)113-1: SMBus MMCRs116-1: Analog Input Channels/Data Registers relationship116-2: Channel and Mode Selection118-1: Keyboard Controller Interface Mapping218-2: KBC Output Buffer Flags Control2                                                  | 61<br>62<br>94<br>97<br>205                                                                                                                                                                 |
| TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE                   | 12-1:SCK Rate as a Function of SPI Clock Rate Select Bits (Master Only).112-2:SCK Rate as a Function of SPI Clock Rate Select Bits (Slave Only).113-1:SMBus MMCRs116-1:Analog Input Channels/Data Registers relationship116-2:Channel and Mode Selection118-1:Keyboard Controller Interface Mapping218-2:KBC Output Buffer Flags Control218-3:KBC Interrupt Control2                            | 61<br>62<br>94<br>97<br>205<br>208                                                                                                                                                          |
| TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE                   | 12-1:SCK Rate as a Function of SPI Clock Rate Select Bits (Master Only)112-2:SCK Rate as a Function of SPI Clock Rate Select Bits (Slave Only)113-1:SMBus MMCRs116-1:Analog Input Channels/Data Registers relationship116-2:Channel and Mode Selection118-1:Keyboard Controller Interface Mapping218-2:KBC Output Buffer Flags Control218-3:KBC Interrupt Control218-4:Mouse Interrupt Control2 | 61<br>62<br>94<br>97<br>205<br>208<br>208                                                                                                                                                   |
| TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE<br>TABLE | 12-1:SCK Rate as a Function of SPI Clock Rate Select Bits (Master Only)112-2:SCK Rate as a Function of SPI Clock Rate Select Bits (Slave Only)113-1:SMBus MMCRs116-1:Analog Input Channels/Data Registers relationship116-2:Channel and Mode Selection118-1:Keyboard Controller Interface Mapping218-2:KBC Output Buffer Flags Control218-3:KBC Interrupt Control218-4:Mouse Interrupt Control2 | <ul> <li>61</li> <li>62</li> <li>66</li> <li>94</li> <li>97</li> <li>205</li> <li>208</li> <li>208</li> <li>208</li> <li>208</li> <li>208</li> <li>208</li> <li>208</li> <li>209</li> </ul> |



| TABLE | 21-1: Mailbox Command/Data Transfer Registers Map     | 220 |
|-------|-------------------------------------------------------|-----|
|       | 21-2: Mailbox Control Registers Map                   |     |
| TABLE | 22-1: SST79LF008 SERIRQ Sampling Periods              | 225 |
| TABLE | 23-1: Configuration Registers Map                     | 228 |
| TABLE | 24-1: Operating Range                                 | 230 |
| TABLE | 24-2: AC Condition of Test                            | 230 |
| TABLE | 24-3: Recommended System Power-up Timing              | 230 |
|       | 24-4: Pin Capacitance                                 |     |
| TABLE | 24-5: Reliability Characteristics                     | 231 |
| TABLE | 24-6: DC Characteristics                              | 231 |
| TABLE | 24-7: LPC Clock Timing Parameters                     | 234 |
|       | 24-8: LPC Read/Write Cycle Timing Parameters          |     |
| TABLE | 24-9: LPC AC Input/Output Specifications              | 235 |
| TABLE | 24-10: LPC Interface Measurement Condition Parameters | 236 |
|       | 24-11: LPC Reset Timing Parameters                    |     |
|       | 24-12: External Clocks and Reset Timing Parameters    |     |
| TABLE | 24-13: SMBus Interface Timing Parameters              | 239 |
|       | 24-14: SMBus Interface Measurement Reference Points   |     |
| TABLE | 24-15: PS/2 Receive Timing Parameters                 | 241 |
|       | 24-16: PS/2 Transmit Timing Parameters                |     |
|       | 24-17: PS/2 Interrupt Timing in bit-banging mode,     |     |
|       | 24-18: PS/2 Interface Measurement Reference Points    |     |
| TABLE | 24-19: UART Timing Parameters.                        | 244 |
| TABLE | 24-20: SPI Timing Parameters.                         | 244 |
|       | 24-21: PWM Output Timing Parameters                   |     |
| TABLE | 24-22: FAN Tachometer Input Timing Parameters         | 248 |
| TABLE | 24-23: aLPC Timing Parameters                         | 248 |
|       | 24-24: ADC Characteristics                            |     |
| TABLE | 24-25: DAC Characteristics                            | 249 |
| TABLE | 26-1: Revision History                                | 252 |
|       |                                                       |     |



# **1.0 FUNCTIONAL BLOCKS**





# 2.0 PIN ASSIGNMENTS

The signal/pin assignments are listed in Table 2-1. Low active signals have a "#" suffix. I/O buffer types are listed in Table 2-2. Section 24.0 defines the DC characteristics for all input and output buffers.

|    | [      |            |         |           | TOF          | VIE         | W (b       | alls fa       | cing d    | own)       |            |            |                  | ]                   |
|----|--------|------------|---------|-----------|--------------|-------------|------------|---------------|-----------|------------|------------|------------|------------------|---------------------|
| 14 |        | KSO0       | KS02    | KSO5      | KSO9         | KSO13       | GPIO105    | ()<br>GPI0109 | ()<br>P11 | ()<br>P15  | PWM1       | PWM2       | MISO             |                     |
| 13 |        | KSO1       | KSO3    | KSO6      | ())<br>KSO10 | KSO14       | $\bigcirc$ | GPIO110       | P12       | ()<br>P16  | OSC1       | MOSI       | SCK              | RESET#              |
| 12 | GPIO6  | 6 GPIO67   | KSO4    | KS07      | ()<br>KSO11  | ()<br>KSO15 | GPIO107    | GPIO111       | ()<br>P13 | ()<br>P17  | OSC2       | ()<br>GA20 | SS#              | PWRGOOD             |
| 11 | GPIO6  | 3 GPIO64   | GPIO65  | KSO8      | KSO12        | GPIO104     | GPIO108    | ()<br>P10     | ()<br>P14 | ()<br>PWM0 | aLAD       | GPIO42     | GPIO41           | EC1_SCI#            |
| 10 | GPIO5  | 9 GPIO60   | GPIO61  | GPIO62    | VSS          | ()<br>VDD   | VSS        | ()<br>VDD     | VSS       | VDD        | SS1        | ()<br>T1   | aFRAME#          | aLCLK               |
| 9  | GPI05  | 5 GPIO56   | GPIO57  | GPIO58    | VDD          |             |            |               |           | VSS        | ()<br>LED1 | ()<br>LED0 | ()<br>T2EX       | SS2                 |
| 8  | SDA0   | ()<br>SCL0 | RXD     | ()<br>TXD | VSS          |             |            |               |           | VSS        | GPIO95     | GPIO94     | ()<br>LED3       | LED2                |
| 7  | LAD3   |            | LPCPD#  | 32KOUT    | VDD          |             |            |               |           | VDD        | SMI#       | ()<br>LED4 | GPIO97           | GPIO96              |
| 6  | LADO   | LAD1       | LAD2    | VDD       | VSS          |             |            |               |           | VSS        | FAN2       | FAN1       | GPIO23           | EC_SCI#             |
| 5  | LRESET | F# SERIRQ  | LFRAME# | VDD       | VSS          | VDD         | VDD        | VSS           | VSS       | VDD        | VDD        | PSCLK0     | SDA2             | SCL2                |
| 4  | VREG   | CLKRUN     | # AVDD  | VSS       | ACH5         | ACH1        | ()<br>T2   | GPIO9         | GPIO101   | KSI13      | KSI9       | PSDAT1     | PSCLK1           | PSDAT0              |
| 3  | AVDD   | AVSS       | VSS     | DAC3      | ACH4         | ACH0        | SS0        | GPIO8         | GPIO100   | KSI12      | KSI8       | KSI5       | PSDAT2           | PSCLK2              |
| 2  | AVSS   | VSS        | DAC1    | ACH7      | ACH3         | CLKOUT      | KBRST#     | GPIO103       | GPIO99    | KSI11      | KSI7       | KSI4       | KSI1             | KSIO                |
| 1  |        | DACO       | DAC2    | ACH6      | ACH2         | WDOUT       | ECLK       | GPIO102       | GPIO98    | KSI10      | KSI6       | KSI3       | KSI2             |                     |
|    | Α      | В          | С       | D         | Е            | F           | G          | Η             | J         | K          | L          | М          | <b>N</b><br>1245 | P<br>176-tfbga P2.1 |

FIGURE 2-1: Pin Assignments for 176-ball TFBGA

# Mobile Platform Controller 8 Mbit LPC Firmware Flash SST79LF008







# 2.1 Pin Descriptions

The pins and functions of each pin in Table 2-1 are organized by each pin's major function. However, some pins are multiplexed with GPIO function.

|                      | I/O Buffer | 176-lead | s or balls | Number  |                                                                                                                                                                                                                       |  |  |
|----------------------|------------|----------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Symbol               | Туре       | LQFP     | TFBGA      | of pins | Name and Functions                                                                                                                                                                                                    |  |  |
| LPC Bus Interface(10 | ))         |          |            |         |                                                                                                                                                                                                                       |  |  |
| LAD3                 | IOPCI      | 156      | A7         | 4       | LPC Address/Data bus LAD[3:0]:                                                                                                                                                                                        |  |  |
| LAD2                 |            | 157      | C6         |         | Multiplexed command, address and data<br>bi-directional bus signals.                                                                                                                                                  |  |  |
| LAD1                 |            | 162      | B6         |         | bi-directional bus signals.                                                                                                                                                                                           |  |  |
| LAD0                 |            | 163      | A6         |         |                                                                                                                                                                                                                       |  |  |
| LCLK                 | IPCI       | 155      | B7         | 1       | LPC Clock: LPC bus clock input signal (commonly the same as PCI clock, up to 33MHz)                                                                                                                                   |  |  |
| LFRAME#              | IPCI       | 164      | C5         | 1       | <b>LPC Frame:</b> LPC bus control input signal.<br>Low pulse indicates the start of the LPC trans-<br>fer cycle when the bus is idle, or the termina-<br>tion (abort) of the broken LPC cycle already in<br>progress. |  |  |
| LPCPD# / GPIO38      | IOD6       | 154      | C7         | 1       | <b>LPC Power Down:</b> LPC Power down input signal, or GPIO Port. Indicates that power will be removed from the LPC bus.                                                                                              |  |  |
| CLKRUN# / GPIO39     | IODPCI     | 167      | B4         | 1       | <b>Clock Run:</b> PCI Clock Control signal, or<br>GPIO Port. Indicates when LPC clock is<br>(about to be) stopped by the LPC host, and<br>provides a mechanism for the LPC device to<br>request clock re-start.       |  |  |
| LRESET#              | IPCI       | 166      | A5         | 1       | <b>LPC Reset:</b> LPC bus reset input signal. This signal is used to reset the LPC interface control logic.                                                                                                           |  |  |
| SERIRQ               | IOPCI      | 165      | B5         | 1       | Serialized IRQ: This signal is used to gener-<br>ate serialized interrupts from the<br>SST79LF008 to the LPC host.                                                                                                    |  |  |
| Keyboard Matrix Inte | rface (30) |          |            |         |                                                                                                                                                                                                                       |  |  |
| KSO15/GPIO37         | IOD4       | 115      | F12        | 4       | KSO[15:12] Keyboard Scan Outputs:                                                                                                                                                                                     |  |  |
| KSO14/GPIO36         |            | 116      | F13        |         | Keyboard Scan output pins, or GPIO Port                                                                                                                                                                               |  |  |
| KSO13/GPIO35         |            | 117      | F14        |         |                                                                                                                                                                                                                       |  |  |
| KSO12/GPIO34         |            | 118      | E11        |         |                                                                                                                                                                                                                       |  |  |



|                    | I/O Buffer | 176-leads  | s or balls | Number  |                                                                                                   |  |  |
|--------------------|------------|------------|------------|---------|---------------------------------------------------------------------------------------------------|--|--|
| Symbol             | Туре       | LQFP TFBGA |            | of pins | Name and Functions                                                                                |  |  |
| KSO11              | OD4        | 119        | E12        | 12      | KSO[11:0] Keyboard Scan Outputs:                                                                  |  |  |
| KSO10              |            | 120        | E13        |         | Keyboard Scan output pins only                                                                    |  |  |
| KSO9               |            | 121        | E14        |         |                                                                                                   |  |  |
| KSO8               |            | 122        | D11        |         |                                                                                                   |  |  |
| KSO7               |            | 123        | D12        |         |                                                                                                   |  |  |
| KSO6               |            | 124        | D13        |         |                                                                                                   |  |  |
| KSO5               |            | 125        | D14        |         |                                                                                                   |  |  |
| KSO4               |            | 126        | C12        |         |                                                                                                   |  |  |
| KSO3               |            | 127        | C13        |         |                                                                                                   |  |  |
| KSO2               |            | 128        | C14        |         |                                                                                                   |  |  |
| KSO1               |            | 129        | B13        |         |                                                                                                   |  |  |
| KSO0               |            | 130        | B14        |         |                                                                                                   |  |  |
| KSI13/GPIO85       | SIO4_PU    | 30         | K4         | 6       | KSI[13:8] Extended Keyboard Scan Inputs:                                                          |  |  |
| KSI12/GPIO84       |            | 31         | K3         |         | 6 individually selectable Keyboard Scan input                                                     |  |  |
| KSI11/GPIO83       |            | 32         | K2         |         | pins (with internal pull-ups and wake up inter-<br>rupts). Each of these pins can be also config- |  |  |
| KSI10/GPIO82       |            | 33         | K1         |         | ured as GPIO with programmable pull-up                                                            |  |  |
| KSI9/GPIO81        |            | 34         | L4         |         | resistors (disabled after reset).                                                                 |  |  |
| KSI8/GPIO80        |            | 35         | L3         |         |                                                                                                   |  |  |
| KSI7               | SI_PU      | 36         | L2         | 8       | KSI[7:0] Keyboard Scan Inputs:                                                                    |  |  |
| KSI6               |            | 37         | L1         |         | 8 Keyboard Scan input pins with internal pull-                                                    |  |  |
| KSI5               |            | 38         | M3         |         | up resistors and wake up interrupts (pull-ups are always enabled).                                |  |  |
| KSI4               |            | 39         | M2         |         | are always enabled).                                                                              |  |  |
| KSI3               |            | 40         | M1         |         |                                                                                                   |  |  |
| KSI2               |            | 41         | N1         |         |                                                                                                   |  |  |
| KSI1               |            | 45         | N2         |         |                                                                                                   |  |  |
| KSI0               |            | 46         | P2         |         |                                                                                                   |  |  |
| PS/2 Interface (6) |            |            |            |         | ·                                                                                                 |  |  |
| PSDAT2/GPIO33      | SIOD15     | 47         | N3         | 3       | PSDAT[2:0] PS/2:Channel 2 to 0 data signal,                                                       |  |  |
| PSDAT1/GPIO31      |            | 49         | M4         |         | or GPIO Port                                                                                      |  |  |
| PSDAT0/GPIO29      |            | 51         | P4         |         |                                                                                                   |  |  |
| PSCLK2/GPIO32      | SIOD15     | 48         | P3         | 3       | PSCLK[2:0] PS/2: Channel 2 to 0 clock sig-                                                        |  |  |
| PSCLK1/GPIO30      |            | 50         | N4         |         | nal, or GPIO Port                                                                                 |  |  |
| PSCLK0/GPIO28      |            | 52         | M5         |         |                                                                                                   |  |  |
| SMBus and UART Int | erface (6) |            |            |         |                                                                                                   |  |  |
| SDA0/GPIO51        | SIO6       | 150        | A8         | 1       | SMBus: Channel 0 data signal, or GPIO port                                                        |  |  |
| SCL0/GPIO52        | SIO6       | 149        | B8         | 1       | SMBus: Channel 0 clock signal, or GPIO port                                                       |  |  |
| RXD/SDA1/GPIO53    | SIO6       | 148        | C8         | 1       | <b>UART:</b> Receive data input, or <b>SMBus</b> chan-<br>nel 1 data signal, or GPIO port         |  |  |
| TXD/SCL1/GPIO54    | SIO6       | 147        | D8         | 1       | <b>UART:</b> Transmit data output, or <b>SMBus</b> chan-<br>nel 1 clock signal, or GPIO port      |  |  |
| SDA2/GPIO27        | SIO6       | 53         | N5         | 1       | SMBus: Channel 2 data signal, or GPIO port                                                        |  |  |
| SCL2/GPIO26        | SIO6       | 54         | P5         | 1       | SMBus: Channel 2 clock signal, or GPIO port                                                       |  |  |

# TABLE 2-1: Pin Descriptions (Continued) (2 of 6)



# TABLE 2-1: Pin Descriptions (Continued) (3 of 6)

|                      | I/O Buffer | 176-lead      | s or balls | Number  |                                                                                                                                    |  |  |
|----------------------|------------|---------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Symbol               | Туре       | LQFP          | TFBGA      | of pins | Name and Functions                                                                                                                 |  |  |
| SPI interface (4)    |            |               |            |         |                                                                                                                                    |  |  |
| MOSI/GPIO3           | IO5        | 91            | M13        | 1       | <b>SPI Data:</b> Master data output line, slave data Input line, or GPIO port                                                      |  |  |
| MISO/GPIO4           | IO5        | 90            | N14        | 1       | <b>SPI Data:</b> Master data input line, slave data output line, or GPIO Port                                                      |  |  |
| SCK/GPIO5            | IO5        | 89            | N13        | 1       | SPI Clock: Master clock output line, slave clock input line, or GPIO Port                                                          |  |  |
| SS#/GPIO6            | IO5        | 86            | N12        | 1       | SPI Port Select: Slave port select input, or GPIO Port                                                                             |  |  |
| aLPC bus, Timers, PV | VMs and Fa | n Tachometers | (12)       | -       |                                                                                                                                    |  |  |
| GPI43/aLAD           | AIO4       | 81            | L11        | 1       | <b>aLPC DATA:</b> Alternative LPC Address/Data<br>Bus or GPI Port                                                                  |  |  |
| GPI44/aLCLK          | AIO4       | 80            | P10        | 1       | <b>aLPC Clock:</b> Alternative LPC clock or GPI Port                                                                               |  |  |
| T0/GPI45/aLFRAME#    | IO5        | 79            | N10        | 1       | <b>Timer0 Counter Input:</b> External count input<br>to Timer/Counter 0, or GPI Port, or aLPC<br>frame: alternative LPC Frame      |  |  |
| T1/GPIO46            | IO5        | 78            | M10        | 1       | <b>Timer1 Counter Input or Output:</b> External count input to Timer/Counter 1, or Clock output from Timer/Counter 1, or GPIO Port |  |  |
| T2/GPIO47            | IO5        | 16            | G4         | 1       | <b>Timer2 Counter Input or Output:</b> External count input to Timer/Counter 2, or Clock output from Timer/Counter 2, or GPIO Port |  |  |
| WDOUT/GPIO48         | IO5        | 15            | F1         | 1       | Watchdog Timer Output: Watchdog Timer Output, or GPIO Port                                                                         |  |  |
| T2EX/GPIO15          | IO5        | 75            | N9         | 1       | <b>Timer 2 External Input:</b> External interrupt input to Timer 2, or GPIO Port                                                   |  |  |
| PWM2/GPIO2           | IO5        | 92            | M14        | 3       | PWM[2:0] PWM Output: PWM output 2 to 0,                                                                                            |  |  |
| PWM1/GPIO1           |            | 97            | L14        |         | or GPIO Port                                                                                                                       |  |  |
| PWM0/GPIO0           |            | 98            | K11        |         |                                                                                                                                    |  |  |
| FAN2/GPIO25          | SIO6       | 56            | L6         | 2       | FAN[2:1] Fan Input: Fan Tachometer input 2                                                                                         |  |  |
| FAN1/GPIO24          |            | 57            | M6         |         | to 1, or GPIO port                                                                                                                 |  |  |
| LED Drivers (5)      |            |               | 1          |         |                                                                                                                                    |  |  |
| LED4/GPIO20          | SIOD15     | 63            | M7         | 5       | LED[4:0] LED Driver output, or GPIO Port                                                                                           |  |  |
| LED3/GPIO19          |            | 71            | N8         |         |                                                                                                                                    |  |  |
| LED2/GPIO18          |            | 72            | P8         |         |                                                                                                                                    |  |  |
| LED1/GPIO17          |            | 73            | L9         |         |                                                                                                                                    |  |  |
| LED0/GPIO16          |            | 74            | M9         |         |                                                                                                                                    |  |  |



|                     | I/O Buffer  | 176-lead  | s or balls | Number  |                                                                                                                          |
|---------------------|-------------|-----------|------------|---------|--------------------------------------------------------------------------------------------------------------------------|
| Symbol              | Туре        | LQFP      | TFBGA      | of pins | Name and Functions                                                                                                       |
| Miscellaneous and D | edicated GP | 2IOs (52) |            |         |                                                                                                                          |
| EC1_SCI#/GPIO40     | SIOD15      | 84        | P11        | 1       | <b>Embedded Controller Interrupt:</b> Embedded controller interrupt output for port 68H/6CH Host interface, or GPIO Port |
| SMI#/GPIO21         | SIOD15      | 62        | L7         | 1       | System Management Interrupt: System management interrupt output, or GPIO Port                                            |
| EC_SCI#/GPIO22      | SIOD15      | 61        | P6         | 1       | <b>Embedded Controller Interrupt:</b> Embedded controller interrupt output for port 62H/66H Host interface, or GPIO Port |
| GPIO23              | SIO6        | 60        | N6         | 1       | GPIO Port                                                                                                                |
| GA20/GPIO7          | IO5         | 85        | M12        | 1       | Gate A20: GA20 output, or GPIO Port                                                                                      |
| KBRST#/GPIO11       | IO5         | 18        | G2         | 1       | <b>KBC Reset to CPU:</b> Keyboard Controller reset output, or GPIO Port                                                  |
| SS2/GPIO14          | IO5         | 76        | P9         | 3       | SS[2:0] LPC Host Status Signals:                                                                                         |
| SS1/GPIO13          |             | 77        | L10        |         | LPC IO Host interface status signal output, or                                                                           |
| SS0/GPIO12          |             | 17        | G3         |         | GPIO Port                                                                                                                |
| GPIO8               | IO5         | 21        | H3         | 5       | GPIO Port                                                                                                                |
| GPIO9               | IO5         | 20        | H4         |         |                                                                                                                          |
| GPIO41              | IO5         | 83        | N11        |         |                                                                                                                          |
| GPIO42              | IO5         | 82        | M11        |         |                                                                                                                          |
| GPIO55              | SIO6        | 146       | A9         |         |                                                                                                                          |
| GPIO67              | IO5         | 134       | B12        | 12      | GPIO Port                                                                                                                |
| GPIO66              |             | 135       | A12        |         |                                                                                                                          |
| GPIO65              |             | 136       | C11        |         |                                                                                                                          |
| GPIO64              |             | 137       | B11        |         |                                                                                                                          |
| GPIO63              |             | 138       | A11        |         |                                                                                                                          |
| GPIO62              |             | 139       | D10        |         |                                                                                                                          |
| GPIO61              |             | 140       | C10        |         |                                                                                                                          |
| GPIO60              |             | 141       | B10        |         |                                                                                                                          |
| GPIO59              |             | 142       | A10        |         |                                                                                                                          |
| GPIO58              |             | 143       | D9         |         |                                                                                                                          |
| GPIO57              |             | 144       | C9         |         |                                                                                                                          |
| GPIO56              |             | 145       | B9         |         |                                                                                                                          |
| P17/GPIO93          | IO5         | 99        | K12        | 8       | P[17:10] 8051 Port1 or GPIO Port                                                                                         |
| P16/GPIO92          |             | 100       | K13        |         |                                                                                                                          |
| P15/GPIO91          |             | 101       | K14        |         |                                                                                                                          |
| P14/GPIO90          |             | 102       | J11        |         |                                                                                                                          |
| P13/GPIO89          |             | 103       | J12        |         |                                                                                                                          |
| P12/GPIO88          |             | 104       | J13        |         |                                                                                                                          |
| P11/GPIO87          |             | 105       | J14        |         |                                                                                                                          |
| P10/GPIO86          |             | 106       | H11        |         |                                                                                                                          |

# TABLE 2-1: Pin Descriptions (Continued) (4 of 6)



| TABLE | 2-1: Pin Descriptions (Continued) (5 of ( | ô) |
|-------|-------------------------------------------|----|
|-------|-------------------------------------------|----|

|                      | I/O Buffer | 176-lead         | ls or balls | Number  |                                                                                                                      |  |  |
|----------------------|------------|------------------|-------------|---------|----------------------------------------------------------------------------------------------------------------------|--|--|
| Symbol               | Туре       | LQFP TFBGA       |             | of pins | Name and Functions                                                                                                   |  |  |
| GPIO111              | SIO4_PU    | 107              | H12         | 18      | GPIO Port: with internal programmable pull-                                                                          |  |  |
| GPIO110              |            | 108              | H13         |         | up resistors (enabled after reset).                                                                                  |  |  |
| GPIO109              |            | 109              | H14         |         |                                                                                                                      |  |  |
| GPIO108              |            | 110              | G11         |         |                                                                                                                      |  |  |
| GPIO107              |            | 111              | G12         |         |                                                                                                                      |  |  |
| GPIO106              |            | 112              | G13         |         |                                                                                                                      |  |  |
| GPIO105              |            | 113              | G14         |         |                                                                                                                      |  |  |
| GPIO104              |            | 114              | F11         |         |                                                                                                                      |  |  |
| GPIO103              |            | 22               | H2          |         |                                                                                                                      |  |  |
| GPIO102              |            | 23               | H1          |         |                                                                                                                      |  |  |
| GPIO101              |            | 26               | J4          |         |                                                                                                                      |  |  |
| GPIO100              |            | 27               | J3          |         |                                                                                                                      |  |  |
| GPIO99               |            | 28               | J2          |         |                                                                                                                      |  |  |
| GPIO98               |            | 29               | J1          |         |                                                                                                                      |  |  |
| GPIO97               |            | <b>-</b> °<br>64 | N7          |         |                                                                                                                      |  |  |
| GPIO96               |            | 65               | P7          |         |                                                                                                                      |  |  |
| GPIO95               |            | 69               | L8          |         |                                                                                                                      |  |  |
| GPIO94               |            | 70               | M8          |         |                                                                                                                      |  |  |
| Analog Interface (12 |            | 70               | NIO         |         |                                                                                                                      |  |  |
| DAC3/GPI071          | AIO4       | 5                | D3          | 4       | DAC[3:0] DAC: Digital to Analog Converter                                                                            |  |  |
| DAC2/GPIO70          | AIO4       | 4                | C1          | 4       | outputs, or GPIO Port                                                                                                |  |  |
| DAC1/GPIO69          |            | 4                | C1<br>C2    |         |                                                                                                                      |  |  |
|                      |            |                  | B1          |         |                                                                                                                      |  |  |
| DAC0/GPIO68          | AIO4       | 2                |             | 0       | ACUIT OI ADO: Angles to Disitel Converter                                                                            |  |  |
| ACH7/GPIO72          | AIO4       | 6                | D2          | 8       | <b>ACH[7:0] ADC:</b> Analog to Digital Converter input, or GPIO Port                                                 |  |  |
| ACH6/GPI073          |            | 7                | D1          |         |                                                                                                                      |  |  |
| ACH5/GPIO74          |            | 8                | E4          |         |                                                                                                                      |  |  |
| ACH4/GPIO75          |            | 9                | E3          |         |                                                                                                                      |  |  |
| ACH3/GPIO76          |            | 10               | E2          |         |                                                                                                                      |  |  |
| ACH2/GPIO77          |            | 11               | E1          |         |                                                                                                                      |  |  |
| ACH1/GPIO78          |            | 12               | F4          |         |                                                                                                                      |  |  |
| ACH0/GPIO79          |            | 13               | F3          |         |                                                                                                                      |  |  |
| Clocks (5)           | - I I      |                  | 1           |         |                                                                                                                      |  |  |
| OSC1                 | OSC        | 95               | L13         | 1       | <b>OSC1 and OSC2:</b> Input and Output of the                                                                        |  |  |
| OSC2                 |            | 94               | L12         | 1       | internal inverting oscillator amplifier. These 2<br>pins are connected to the external 32.768KHz<br>crystal circuit. |  |  |
| 32KOUT/GPIO50        | IO5        | 151              | D7          | 1       | <b>32KHz Clock:</b> Output of 32.768Khz clock signal, or GPIO Port                                                   |  |  |
| ECLK/GPIO10          | IO5        | 19               | G1          | 1       | ECLK: External Clock input, or GPIO Port                                                                             |  |  |
| CLKOUT/GPIO49        | IO5        | 14               | F2          | 1       | Core Clock Output: 8051 core clock output, or GPIO Port                                                              |  |  |



|                     | I/O Buffer | 176-leads                                                                 | s or balls                                                            | Number  |                                                                                                                                        |
|---------------------|------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------|
| Symbol              | Туре       | LQFP                                                                      | TFBGA                                                                 | of pins | Name and Functions                                                                                                                     |
| Reset, ID and Power | r (34)     |                                                                           |                                                                       |         |                                                                                                                                        |
| PWRGOOD             | I          | 87                                                                        | P12                                                                   | 1       | Power Good: Input used to select clock source                                                                                          |
| RESET#              | SI_PU      | 88                                                                        | P13                                                                   | 1       | <b>Reset:</b> By setting the RESET# pin low, the entire device is reset to a default state (internal pull-up resistor always enabled). |
| ID                  | I_PD       | 131                                                                       | A13                                                                   | 1       | <b>Firmware Memory ID:</b> LPC Firmware mem-<br>ory ID selection input (internal pull-down<br>resistor always enabled).                |
| V <sub>DD</sub>     | PWR        | 1, 24, 43,<br>44 58, 66,<br>93, 132, 152,<br>158, 159, 170                | F5, G5, K5,<br>L5, K7, K10,<br>H10, F10, E9,<br>E7, D6, D5            | 12      | <b>Digital Power supply 3.3V:</b><br>(power supply voltage must be applied to all V <sub>DD</sub> pins)                                |
| AV <sub>DD</sub>    | PWR        | 172,173                                                                   | C4, A3                                                                | 2       | Analog Power Supply 3.3V:<br>(analog power supply voltage must be applied<br>to all AV <sub>DD</sub> pins)                             |
| V <sub>SS</sub>     | PWR        | 25, 42, 55,<br>59, 67, 68,<br>96, 133, 153,<br>160, 161, 168,<br>169, 176 | H5, J5, K6,<br>K8, K9, J10,<br>G10, E10, E8,<br>E6, E5, D4,<br>C3, B2 | 14      | <b>Ground (GND):</b> 0V reference<br>(ground plane must be connected to all V <sub>SS</sub><br>pins)                                   |
| AV <sub>SS</sub>    | PWR        | 174, 175                                                                  | B3, A2                                                                | 2       | <b>Analog Ground:</b> For ADC and DAC (analog ground plane must be connected to all AV <sub>SS</sub> pins as well as to GND plane)     |
| VREG                | PWR        | 171                                                                       | A4                                                                    | 1       | Internal voltage regulator output:<br>An external ceramic capacitor (1µf) must be<br>connected between this pin and<br>system ground.  |

## TABLE 2-1: Pin Descriptions (Continued) (6 of 6)

T2-1.1 1320



# 2.2 I/O Type Descriptions

I/O buffer types in Table 2-1 are described in Table 2-2. DC parameters are described in Section 24.0.

| I/O Buffer Type | Description                                                              |
|-----------------|--------------------------------------------------------------------------|
| AIO4            | I/O with push-pull 4mA output multiplexed with Analog function           |
| 1               | Input                                                                    |
| I_PD            | Input with internal pull-down                                            |
| IO5             | I/O with push-pull 5mA output                                            |
| IOD4            | Input, open drain output with 4mA sink capability                        |
| IOD6            | Input, open drain output with 6mA sink capability                        |
| IODPCI          | Input, open drain output, PCI compatible                                 |
| IOPCI           | I/O, PCI compatible                                                      |
| IPCI            | Input, PCI compatible                                                    |
| OSC             | 32 kHz oscillator input and output                                       |
| OD4             | Open drain output with 4mA sink capability                               |
| SI_PU           | Schmitt triggered input with internal pull-up                            |
| SIO4_PU         | I/O with Schmitt triggered input, push-pull 4mA output, internal pull-up |
| SIO6            | I/O with Schmitt triggered input, push-pull 6mA output                   |
| SIOD15          | Schmitt triggered input, open drain output with 15mA sink capability     |
| PWR             | Power or Ground pin                                                      |

# TABLE 2-2: I/O Buffer Types<sup>1</sup>

1. Any pin configured as input or OD high output without internal pull-up or pull-down resistor must not be left disconnected.

T2-2.1 1320



# 3.0 MEMORY ORGANIZATION

The on-chip 8051 MCU has separate address spaces for program and data memory, which are described in this section. The on-chip 8051 can also access, via Shared ROM Interface, a total of 1 MByte (8 Mbits) of the main Flash Memory array, 4 KByte of ENVR flash sector, and

3 KBytes of UNVR one-time programmable memory. The main Flash Memory array is divided into 16 blocks with 64 KByte block size, each block consists of 16 sectors with 4 KByte sector size. The entire main array as well as ENVR can be erased/programmed/read by the 8051 core using in-application programming mode commands specified in Section 4.0. However, only the two bottom blocks of the main array can be mapped into 8051 program space.

# 3.1 Program Memory

The SST79LF008 enhanced 8051 MCU can operate either in 16-bit addressing mode with firmware size up to 64 KByte, or in 17-bit addressing mode with firmware size up to 128 KByte. Flash memory Block 0 is mapped to 8051 program memory to store firmware code in 16-bit addressing mode, and Flash memory Blocks 0 and 1 are mapped to 8051 program memory to store firmware code in 17-bit addressing mode. For program memory organization, see Figure 3-1. The addressing mode is controlled by ACON register, described in Section 6.5.

Additionally, sections of the on-chip SRAM can be mapped into the 8051 program space providing a so called Scratch ROM area for code that can run during in-application programming. The size of Scratch ROM can be selected as 2 KByte, 1 KByte, 512 Byte, or 256 Byte. See Figures 3-2, 3-3, 3-4, and 3-5. Scratch ROM mapping and size is controlled by SCRROM register, defined in Section 4.4.1.



FIGURE 3-1: SST79LF008 Program Memory Organization





#### FIGURE 3-2: 2 KByte Scratch ROM Mapping





# Mobile Platform Controller 8 Mbit LPC Firmware Flash SST79LF008











# 3.2 Data Memory

The on-chip 2304-Byte SRAM can be divided into three sections:

- 1. Lower RAM SRAM section mapped to the lower 128 Bytes of 8051 Internal Data Memory space (00H to 7FH), that are directly and indirectly addressable.
- 2. Upper RAM SRAM section mapped into the higher 128 Bytes of 8051 Internal Data Memory space (80H to FFH), that are indirectly address-able only.
- 3. Expanded RAM SRAM section mapped into 2048 bytes of 8051 External Data Memory space (0000H to 07FFH) that are indirectly addressable via 8051 external memory access instructions

only. (As described in Section 3.1, 256, 512, 1024 or 2048 Bytes of this SRAM section can be also remapped to the 8051 program address space providing a Scratch ROM area.)

The on-chip Special Function Registers (SFRs) are mapped into the higher 128 Bytes of 8051 Internal Data Memory space (80H to FFH), and thus overlapped with Upper RAM. However, unlike Upper RAM, all SFRs are directly addressable only.

The on-chip Memory Mapped Configuration registers (MMCRs) are mapped into 256 bytes of 8051 External Data Memory space (7F00H to 7FFFH) that are indirectly addressable via 8051 external memory access instructions only.





# 3.3 Data Memory Addressing Modes

The Lower RAM is accessed by all 8051 instructions that utilize both direct and indirect internal data memory addressing modes. In addition the lowest 32 bytes (00H-1FH) of Lower RAM are grouped into 4 banks of 8 registers, which can be accessed by 8051 register addressing mode. Bytes 20H-2FH provide a 128-bit addressable space, accessible by 8051 bit addressing mode (bit addresses 00H-7FH).

Because the Upper RAM occupies the same addresses as the SFRs, the respective data areas are distinguished by the type of addressing mode used: the Upper RAM is accessed via indirect internal data memory addressing mode, and the SFRs are accessed via direct internal data memory addressing mode. The SFRs that are located at addresses ended with 0H or 8H are also bit-addressable (bit addresses 80H-FFH).

The entire Expanded RAM and MMCRs are accessed by 8051 MOVX instructions that utilize indirect external data memory addressing mode and DPTR pointer. Using MOVX with R0/R1 indirect pointer can only access the lowest 256 bytes of total 2KB Expanded RAM.

The 8051 stack with default 8-bit addressing mode can be located anywhere within the 256 bytes of Lower and/or Upper RAM.

For additional details on 8051 addressing modes refer to the description of standard 8051 instruction set. For the SST79LF008 enhanced 8051 MCU features, see Section 6.0.

# 3.4 Special Function Registers (SFRs)

All Special Function Registers are located in 8051 internal data memory space, addresses 80H – FFH. For the detailed description of SFRs see the respective sections as specified in Tables 3-2, 3-3, 3-4, and 3-5. Some of SFRs contain reserved bits. On reads, software must not rely on reserved bits being any particular value. On writes, zeros should be written to reserved bits. When modifying a register with reserved bits the values read from the reserved bits can be written back to them. Software should not write to non used locations in SFR space.

#### 3.4.1 SFR Map

|     |                    |       |        | 8 BY   | TES |      |      |        |
|-----|--------------------|-------|--------|--------|-----|------|------|--------|
| F8H | IPA <sup>1</sup>   |       |        |        |     |      |      |        |
| F0H | B1                 |       |        |        |     |      |      | IPAH   |
| E8H | IEA <sup>1</sup>   |       |        |        |     |      |      |        |
| E0H | ACC <sup>1</sup>   |       |        |        |     |      |      |        |
| 08H |                    |       |        |        |     |      |      |        |
| D0H | PSW <sup>1</sup>   |       |        |        |     | SPCR |      |        |
| C8H | T2CON <sup>1</sup> | T2MOD | RCAP2L | RCAP2H | TL2 | TH2  |      |        |
| юн  |                    |       |        |        |     |      |      |        |
| 8H  | IP <sup>1</sup>    | SADEN |        |        |     |      |      |        |
| 0H  | P3 <sup>1</sup>    |       |        |        |     |      |      | IPH    |
| 8H  | IE <sup>1</sup>    | SADDR | SPSR   | EXIF   |     |      |      | CLKCON |
| .0H | P2 <sup>1</sup>    |       | AUXR1  |        |     |      |      |        |
| 8H  | SCON <sup>1</sup>  | SBUF  |        | ESP    |     | ACON |      |        |
| ЮH  | P1 <sup>1</sup>    |       |        | DPX    |     |      |      |        |
| 88H | TCON <sup>1</sup>  | TMOD  | TL0    | TL1    | TH0 | TH1  |      |        |
| 80H | P0 <sup>1</sup>    | SP    | DPL    | DPH    |     |      | SPDR | PCON   |

## TABLE 3-1: Special Function Register Memory Map

1. Bit addressable SFRs

Function and bit definitions for registers ACC, B, PSW, and P1 are the same as in standard 8051 MCU. Registers P0, P2, P3 are reserved. For the detailed description of all other SFRs see the respective sections as specified in the reference charts below.



## 3.4.2 SFR References

| TABLE | 3-2: Miscellaneous SFRs Reference |
|-------|-----------------------------------|
|-------|-----------------------------------|

|               |         |                          |   | E | Bit A | Acce | ess | Туре | 9 |   |                          |                                           |
|---------------|---------|--------------------------|---|---|-------|------|-----|------|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3   | 2    | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| P1            | 90H     | -                        | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      | Q: Read and Write                         |
| PSW           | D0H     | -                        | Q | R | Q     | Q    | Q   | R    | Q | R | 00H                      | R: Read Only                              |
| ACC           | E0H     | -                        | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      | W: Write Only                             |
| В             | F0H     | -                        | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      | -: Reserved Bit<br>x: Indeterminate Value |
| CLKCON        | AFH     | 6.3.1                    | - | - | -     | -    | Ø   | Q    | Q | Q | xxxx0100b                |                                           |
| EXIF          | ABH     | 8.3.1                    | - | - | -     | -    | R   | R    | R | R | x0H                      |                                           |
| IE            | A8H     | 8.3.2                    | Q | - | Q     | Q    | Q   | Q    | Q | Q | 0x000000b                |                                           |
| IEA           | E8H     | 8.3.3                    | - | - | -     | -    | Q   | Q    | Q | Q | x0H                      |                                           |
| IP            | B8H     | 8.3.4                    | Q | - | Q     | Q    | Q   | Q    | Q | Q | 0x000000b                |                                           |
| IPH           | B7H     | 8.3.5                    | Q | - | Q     | Q    | Ø   | Q    | Q | Q | 0x000000b                |                                           |
| IPA           | F8H     | 8.3.6                    | - | - | -     | -    | Q   | Q    | Q | Q | x0H                      |                                           |
| IPAH          | F7H     | 8.3.7                    | - | - | -     | -    | Ø   | Q    | Q | Q | x0H                      |                                           |
| AUXR1         | A2H     | 6.4.1                    | - | - | -     | -    | I   | -    | 1 | Q | xxxxxxx0b                |                                           |
| ACON          | 9DH     | 6.5.1                    | - | - | -     | -    | I   | Q    | Q | - | xxxxx00xb                |                                           |
| SP            | 81H     | 6.5.3                    | Q | Q | Q     | Q    | Ø   | Q    | Q | Q | 07H                      |                                           |
| ESP           | 9BH     | 6.5.2                    | - | - | 1     | 1    | -   | Q    | Q | Q | xxxxx000b                |                                           |
| DPL           | 82H     | 6.4.2                    | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      |                                           |
| DPH           | 83H     | 6.4.3                    | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      |                                           |
| DPX           | 93H     | 6.4.4                    | - | - | -     | -    | -   | -    | - | Q | xxxxxxx0b                | T0.0.0.1220                               |

T3-2.0 1320

1. All SFRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).

|               |         |                          | Bit Access Type |   |   |   |   |   |   |   |                          |                                           |
|---------------|---------|--------------------------|-----------------|---|---|---|---|---|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7               | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| TCON          | 88H     | 10.3.1                   | Q               | Q | Q | Q | R | R | R | R | 00H                      | Q: Read and Write                         |
| TMOD          | 89H     | 10.3.2                   | R               | Q | Q | Q | R | Q | Q | Q | 00H                      | R: Read Only                              |
| TL0           | 8AH     | 10-1                     | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      | W: Write Only                             |
| TL1           | 8BH     | 10-1                     | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      | -: Reserved Bit<br>x: Indeterminate Value |
| TH0           | 8CH     | 10-1                     | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      | x. Indeterminate value                    |
| TH1           | 8DH     | 10-1                     | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| T2CON         | C8H     | 10.3.3                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| T2MOD         | C9H     | 10.3.4                   | 1               | 1 | 1 | - | 1 | Q | Q | Q | x0H                      |                                           |
| RCAP2L        | CAH     | 10-1                     | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| RCAP2H        | CBH     | 10-1                     | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| TL2           | ССН     | 10-1                     | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| TH2           | CDH     | 10-1                     | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |

## TABLE3-3: Timer SFRs Reference

T3-3.0 1320

1. All SFRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).



#### TABLE3-4: UART SFRs References

|                      |         |                          |   | E | Bit A | Acce | ess <sup>-</sup> | Гуре | Э |   |                                       |                                           |
|----------------------|---------|--------------------------|---|---|-------|------|------------------|------|---|---|---------------------------------------|-------------------------------------------|
| <b>Register Name</b> | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3                | 2    | 1 | 0 | Reset Value <sup>1</sup>              | Кеу                                       |
| PCON                 | 87H     | 11.4.1                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00x <sup>2</sup> x <sup>3</sup> 0000b | Q: Read and Write                         |
| SADDR                | A9H     | 11.4.2                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                                   | R: Read Only                              |
| SADEN                | B9H     | 11.4.3                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                                   | W: Write Only                             |
| SBUF                 | 99H     | 11.4.4                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | xxH                                   | -: Reserved Bit<br>x: Indeterminate Value |
| SCON                 | 98H     | 11.4.5                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                                   | x. Indeterminate value                    |

T3-4.0 1320

1. All SFRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).

2. Bit 5 of PCON register (Brown-Out Flag) is cleared by Power-On reset, and it is not affected by other reset events.

3. Bit 4 of PCON register (Power-On Flag) is set by Power-On reset, and it is not affected by other reset events.

TABLE 3-5: SPI SFRs References

|               |         |                          |   | E | Bit A | Acce | ss . | Туре | e |   |                          |                        |
|---------------|---------|--------------------------|---|---|-------|------|------|------|---|---|--------------------------|------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3    | 2    | 1 | 0 | Reset Value <sup>1</sup> | Кеу                    |
| SPCR          | D5H     | 12.4.1                   | Q | - | Q     | Q    | Q    | Q    | Q | Q | 0x000100b                | Q: Read and Write      |
| SPSR          | AAH     | 12.4.2                   | Q | Q | -     | -    | -    | -    | - | - | 00xxxxxb                 | -: Reserved Bit        |
| SPDR          | 86H     | 12.4.3                   | Q | Q | Q     | Q    | Q    | Q    | Q | Q | 00H                      | x: Indeterminate Value |

T3-5.0 1320

1. All SFRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).



# 3.5 Memory Mapped Configuration Registers (MMCR)

All Memory Mapped Configuration Registers are located in 8051 external data memory space, addresses 7F00H – 7FFFH. For the detailed description of MMCRs see the respective sections as specified Tables 3-6 through 3-25. Some of MMCRs contain reserved bits. On reads software must not rely on reserved bits being any particular value. On writes zeros should be written to reserved bits. When modifying a register with reserved bits the values read from the reserved bits can be written back to them. Software should not write to unused locations in MMCR space.

## 3.5.1 MMCR References

|               |         |                          | Bit Access Type |   |   |   |   |   |   |   |                          |                                              |
|---------------|---------|--------------------------|-----------------|---|---|---|---|---|---|---|--------------------------|----------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7               | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                          |
| GPIOAIN       | 7F1AH   | 9.1.2                    | R               | R | R | R | R | R | R | R | ррН                      | Q: Read and Write                            |
| GPIOBIN       | 7F1DH   | 9.1.6                    | R               | R | R | R | R | R | R | R | ррН                      | R: Read Only                                 |
| GPIOCIN       | 7F20H   | 9.1.11                   | R               | R | R | R | R | R | R | R | ррН                      | W: Write Only                                |
| GPIODIN       | 7F24H   | 9.1.15                   | R               | R | R | R | R | R | R | R | ррН                      | -: Reserved Bit<br>p: Pass through pin state |
| GPIOEIN       | 7FA2H   | 9.1.18                   | R               | R | R | R | R | R | R | R | ррН                      | p. Fass infough pin state                    |
| GPIOFIN       | 7FA5H   | 9.1.22                   | R               | R | R | R | R | R | R | R | ррН                      |                                              |
| GPIOGIN       | 7F3BH   | 9.1.26                   | R               | R | R | R | R | R | R | R | ррН                      |                                              |
| GPIOHIN       | 7FE2H   | 9.1.30                   | R               | R | R | R | R | R | R | R | ррН                      |                                              |
| GPIOIIN       | 7FE5H   | 9.1.34                   | R               | R | R | R | R | R | R | R | ррН                      |                                              |
| GPIOJIN       | 7FE8H   | 9.1.39                   | R               | R | R | R | R | R | R | R | ррН                      |                                              |
| GPIOKIN       | 7FEBH   | 9.1.44                   | R               | R | R | R | R | R | R | R | ррН                      |                                              |
| GPIOLIN       | 7FA9H   | 9.1.48                   | R               | R | R | R | R | R | R | R | ррН                      | ]                                            |
| GPIOMIN       | 7F6BH   | 9.1.51                   | R               | R | R | R | R | R | R | R | ррН                      | ]                                            |
| GPIONIN       | 7F84H   | 9.1.55                   | R               | R | R | R | R | R | R | R | ррН                      |                                              |

#### TABLE 3-6: GPIO Input MMCRs References

1. All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).



|               |         |                          | Bit Access Type |   |   |   |   |   |   |   |                          |                                           |
|---------------|---------|--------------------------|-----------------|---|---|---|---|---|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7               | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| GPIOAOUT      | 7F19H   | 9.1.3                    | Q               | Q | Q | Q | Q | Q | Q | Q | FFH                      | Q: Read and Write                         |
| GPIOBOUT      | 7F1CH   | 9.1.7                    | Q               | Q | Q | Q | Q | Q | Q | Q | FFH                      | R: Read Only                              |
| GPIOCOUT      | 7F1FH   | 9.1.12                   | Q               | Q | Q | Q | Q | Q | Q | Q | FFH                      | W: Write Only                             |
| GPIODOUT      | 7F23H   | 9.1.16                   | Q               | Q | Q | Q | Q | Q | Q | Q | FFH                      | -: Reserved Bit<br>x: Indeterminate Value |
| GPIOEOUT      | 7FA1H   | 9.1.19                   | Q               | Q | Q | Q | Q | Q | Q | Q | FFH                      |                                           |
| GPIOFOUT      | 7FA4H   | 9.1.23                   | Q               | Q | - | - | - | Q | Q | Q | 11xxx111b                |                                           |
| GPIOGOUT      | 7F3AH   | 9.1.27                   | Q               | Q | Q | Q | Q | Q | Q | Q | FFH                      |                                           |
| GPIOHOUT      | 7FE1H   | 9.1.31                   | Q               | Q | Q | Q | Q | Q | Q | Q | FFH                      |                                           |
| GPIOIOUT      | 7FE4H   | 9.1.35                   | Q               | Q | Q | Q | Q | Q | Q | Q | FFH                      |                                           |
| GPIOJOUT      | 7FE7H   | 9.1.40                   | Q               | Q | Q | Q | Q | Q | Q | Q | FFH                      |                                           |
| GPIOKOUT      | 7FEAH   | 9.1.45                   | Q               | Q | Q | Q | Q | Q | Q | Q | FFH                      |                                           |
| GPIOLOUT      | 7FA8H   | 9.1.49                   | Q               | Q | Q | Q | Q | Q | Q | Q | FFH                      |                                           |
| GPIOMOUT      | 7F30H   | 9.1.52                   | Q               | Q | Q | Q | Q | Q | Q | Q | FFH                      |                                           |
| GPIONOUT      | 7F82H   | 9.1.56                   | Q               | Q | Q | Q | Q | Q | Q | Q | FFH                      |                                           |

#### TABLE 3-7: GPIO Output MMCRs References

All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).

#### TABLE 3-8: GPIO Direction MMCRs References

|               |         |                          |   | E | Bit A | Acce | ess | Туре | e |   |                          |                                           |
|---------------|---------|--------------------------|---|---|-------|------|-----|------|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3   | 2    | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| GPIOADIR      | 7F18H   | 9.1.1                    | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      | Q: Read and Write                         |
| GPIOBDIR      | 7F1BH   | 9.1.5                    | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      | R: Read Only                              |
| GPIOCDIR      | 7F1EH   | 9.1.10                   | Q | - | -     | 1    | -   | -    | 1 | - | 0xxxxxxb                 | W: Write Only                             |
| GPIODDIR      | 7F22H   | 9.1.14                   | - | - | -     | -    | Q   | Q    | Q | Q | x0H                      | -: Reserved Bit<br>x: Indeterminate Value |
| GPIOFDIR      | 7FA3H   | 9.1.21                   | Q | Q | -     | -    | -   | Q    | Q | - | 00xxx00xb                | x. Indeterminate value                    |
| GPIOGDIR      | 7F39H   | 9.1.25                   | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      |                                           |
| GPIOHDIR      | 7FE0H   | 9.1.29                   | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      |                                           |
| GPIOIDIR      | 7FE3H   | 9.1.33                   | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      |                                           |
| GPIOJDIR      | 7FE6H   | 9.1.38                   | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      |                                           |
| GPIOKDIR      | 7FE9H   | 9.1.43                   | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      |                                           |
| GPIOLDIR      | 7FA7H   | 9.1.47                   | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      |                                           |
|               |         |                          |   |   |       |      |     |      |   |   |                          | T3-8.0 1320                               |

1. All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).



|               |         |                          |   | E | Bit A | Acce | ess <sup>-</sup> | Гуре | e |   |                          |                                                            |
|---------------|---------|--------------------------|---|---|-------|------|------------------|------|---|---|--------------------------|------------------------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3                | 2    | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                                        |
| GPIOASEL      | 7F3DH   | 9.1.4                    | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                      | Q: Read and Write                                          |
| GPIOBSEL      | 7F40H   | 9.1.8                    | Q | Q | Q     | Q    | Q                | Q    | - | - | 000000xxb                | R: Read Only                                               |
| GPIOCSEL      | 7FDCH   | 9.1.13                   | - | Q | Q     | Q    | Q                | Q    | Q | Q | x0000000b                | W: Write Only<br>-: Reserved Bit<br>x: Indeterminate Value |
| GPIODSEL      | 7FDDH   | 9.1.17                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                      |                                                            |
| GPIOESEL      | 7FDEH   | 9.1.20                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | C0H                      |                                                            |
| GPIOFSEL      | 7FA6H   | 9.1.24                   | Q | Q | Q     | -    | -                | -    | - | Q | 000xxxx0b                |                                                            |
| GPIOGSEL      | 7F3CH   | 9.1.28                   | - | Q | Q     | Q    | Q                | Q    | Q | Q | x0000000b                |                                                            |
| GPIOHLOD      | 7FABH   | 9.1.32                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                      |                                                            |
| GPIOISEL      | 7FF0H   | 9.1.36                   | Q | Q | Q     | Q    | -                | -    | - | - | 0xH                      |                                                            |
| GPIOIOD       | 7FACH   | 9.1.37                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                      |                                                            |
| GPIOJSEL      | 7FF5H   | 9.1.41                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                      |                                                            |
| GPIOJOD       | 7FADH   | 9.1.42                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                      |                                                            |
| GPIOKPU       | 7FB7H   | 9.1.46                   | - | - | Q     | Q    | Q                | Q    | Q | Q | xx000000b                |                                                            |
| GPIOMPU       | 7F5BH   | 9.1.50                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                      |                                                            |
| GPIOMOD       | 7FF6H   | 9.1.53                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                      |                                                            |
| GPIONPU       | 7F83H   | 9.1.54                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                      |                                                            |
| GPIONOD       | 7FFCH   | 9.1.57                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                      |                                                            |

## TABLE 3-9: GPIO Function Selection MMCRs References

1. All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).



|               |         |                          | Bit Access Type |   |   |   |   |   |   |   |                          |                                           |
|---------------|---------|--------------------------|-----------------|---|---|---|---|---|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7               | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| GPIOESA       | 7F57H   | 8.3.19                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      | Q: Read and Write                         |
| GPIOESB       | 7F58H   | 8.3.22                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      | R: Read Only                              |
| GPIOESC       | 7F5CH   | 8.3.25                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      | W: Write Only                             |
| GPIOESD       | 7F5DH   | 8.3.28                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      | -: Reserved Bit<br>x: Indeterminate Value |
| GPIOESE       | 7F60H   | 8.3.31                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      | A. Indeterminate value                    |
| GPIOESF       | 7F61H   | 8.3.34                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOESG       | 7F62H   | 8.3.37                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOESH       | 7F6CH   | 8.3.40                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOESI       | 7F6DH   | 8.3.43                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOESJ       | 7F6EH   | 8.3.44                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOESK       | 7F6FH   | 8.3.47                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOESL       | 7FD0H   | 8.3.48                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOESM       | 7FD1H   | 8.3.51                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOESN       | 7FD2H   | 8.3.52                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOKINT      | 7FB8H   | 8.3.53                   | -               | - | Q | Q | Q | Q | Q | Q | xx000000b                |                                           |
| GPIOESO       | 7FD3H   | 8.3.56                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOESP       | 7FD4H   | 8.3.57                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOESQ       | 7FD5H   | 8.3.60                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOESR       | 7FD6H   | 8.3.61                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOESS       | 7FD7H   | 8.3.64                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| GPIOEST       | 7FD8H   | 8.3.65                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |

#### TABLE 3-10: GPIO Active Edge Selection MMCRs References

T3-10.0 1320

1. All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).

| TABLE | 3-11: I | nterrupt S | Source MMCRs Refe | erences |
|-------|---------|------------|-------------------|---------|
|       |         |            |                   |         |

|               |         |                          |   | E | Bit A | Acce | ess <sup>-</sup> | Туре | e |   |                          |                                           |
|---------------|---------|--------------------------|---|---|-------|------|------------------|------|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3                | 2    | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| INTSRCA       | 7F00H   | 8.3.8                    | R | R | R     | R    | 1                | R    | Q | R | 1000x000b                | Q: Read and Write                         |
| INTSRCAMSK    | 7F01H   | 8.3.9                    | Q | Q | Q     | Q    | -                | Q    | Q | Q | 0000x000b                | R: Read Only                              |
| INTSRCB       | 7F02H   | 8.3.10                   | R | R | R     | R    | R                | R    | R | R | 90H                      | W: Write Only                             |
| INTSRCBMSK    | 7F03H   | 8.3.11                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                      | -: Reserved Bit<br>x: Indeterminate Value |

T3-11.0 1320

1. All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).



# Mobile Platform Controller 8 Mbit LPC Firmware Flash SST79LF008

Advance Information

## TABLE 3-12: Wakeup Source MMCRs References

|               |         |                          | Bit Access Type |   |   |   |   |   |   |   |                          |                                           |
|---------------|---------|--------------------------|-----------------|---|---|---|---|---|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7               | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| WSRCA         | 7F2AH   | 8.3.12                   | Q               | Q | Q | Q | Q | - | R | Q | 00000x10b                | Q: Read and Write                         |
| WSRCAMSK      | 7F2BH   | 8.3.13                   | Q               | Q | Q | Q | Q | - | Q | Q | 00000x00b                | R: Read Only                              |
| WSRCB         | 7F2CH   | 8.3.14                   | R               | R | - | - | Q | Q | Q | Q | 00xx0000b                | W: Write Only                             |
| WSRCBMSK      | 7F2DH   | 8.3.15                   | Q               | Q | - | - | Q | Q | Q | Q | 00xx0000b                | -: Reserved Bit<br>x: Indeterminate Value |
| KEYWSRC       | 7F2FH   | 8.3.16                   | -               | - | - | - | - | - | Q | Q | xxxxxx00b                | x. muelemmale value                       |
| WSRCC         | 7F59H   | 8.3.17                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCCMSK      | 7F5AH   | 8.3.18                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCD         | 7F5EH   | 8.3.20                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCDMSK      | 7F5FH   | 8.3.21                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCE         | 7F63H   | 8.3.23                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCEMSK      | 7F66H   | 8.3.24                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCF         | 7F64H   | 8.3.26                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCFMSK      | 7F65H   | 8.3.27                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCG         | 7F55H   | 8.3.29                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCGMSK      | 7F56H   | 8.3.30                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCH         | 7FAEH   | 8.3.32                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCHMSK      | 7FAFH   | 8.3.33                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCI         | 7F3EH   | 8.3.35                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCIMSK      | 7F3FH   | 8.3.36                   | Q               | Q | Q | Q | Ø | Q | Q | Q | 00H                      |                                           |
| WSRCJ         | 7FC8H   | 8.3.38                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCJMSK      | 7FC9H   | 8.3.39                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCK         | 7FCAH   | 8.3.41                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCKMSK      | 7FCBH   | 8.3.42                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCL         | 7FCCH   | 8.3.45                   | Q               | Q | Ø | Q | Ø | Ø | Ø | Q | 00H                      |                                           |
| WSRCLMSK      | 7FCDH   | 8.3.46                   | Q               | Q | Q | Q | Ø | Q | Q | Q | 00H                      |                                           |
| WSRCM         | 7FCEH   | 8.3.49                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCMMSK      | 7FCFH   | 8.3.50                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCN         | 7FB0H   | 8.3.54                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCNMSK      | 7FB1H   | 8.3.55                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCO         | 7FDBH   | 8.3.58                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCOMSK      | 7FECH   | 8.3.59                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCP         | 7FEDH   | 8.3.62                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |
| WSRCPMSK      | 7FEEH   | 8.3.63                   | Q               | Q | Q | Q | Q | Q | Q | Q | 00H                      |                                           |

T3-12.0 1320 1. All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).



### TABLE 3-13: Timer MMCRs References

|               |         |                          |   | Bit Access Type |   |   |   |   |   |   |                          |                                                            |
|---------------|---------|--------------------------|---|-----------------|---|---|---|---|---|---|--------------------------|------------------------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6               | 5 | 4 | 3 | 2 | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                                        |
| WDTCSR        | 7F37H   | 10.4.1.1                 | Q | -               | 1 | - | 1 | I | Q | Q | 0xxxxx00b                | Q: Read and Write                                          |
| WDTDAT        | 7F38H   | 10.4.1.2                 | Q | Q               | Q | Q | Q | Q | Q | Q | FFH                      | R: Read Only                                               |
| HIBER         | 7FF3H   | 10.5.1                   | Q | Q               | Q | Q | Q | Q | Q | Q | 00H                      | W: Write Only<br>-: Reserved Bit<br>x: Indeterminate Value |

T3-13.0 1320

1. All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).

|               |         |                          |   | E | Bit A | lcce | ss | Тур | е |   |                          |                                           |
|---------------|---------|--------------------------|---|---|-------|------|----|-----|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3  | 2   | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| PWMPL0        | 7F25H   | 10.6.1.1                 | Q | Q | Q     | Q    | Q  | Q   | Q | Ø | FFH                      | Q: Read and Write                         |
| PWMPL1        | 7F26H   | 10.6.1.2                 | Q | Q | Q     | Q    | Q  | Q   | Q | Ø | FFH                      | R: Read Only                              |
| PWMPL2        | 7F29H   | 10.6.1.3                 | Q | Q | Q     | Q    | Q  | Q   | Q | Ø | FFH                      | W: Write Only                             |
| PWMPH0        | 7F97H   | 10.6.1.4                 | Q | Q | Q     | Q    | Q  | Q   | Q | Q | FFH                      | -: Reserved Bit<br>x: Indeterminate Value |
| PWMPH1        | 7F98H   | 10.6.1.5                 | Q | Q | Q     | Q    | Q  | Q   | Q | Q | FFH                      | p: Pass through pin state                 |
| PWMPH2        | 7F99H   | 10.6.1.6                 | Q | Q | Q     | Q    | Q  | Q   | Q | Q | FFH                      |                                           |
| PWMC0         | 7F9AH   | 10.6.1.7                 | Q | Q | Q     | Q    | Q  | Q   | Q | Ø | FFH                      |                                           |
| PWMC1         | 7F9BH   | 10.6.1.8                 | Q | Q | Q     | Q    | Q  | Q   | Q | Q | FFH                      |                                           |
| PWMC2         | 7F9CH   | 10.6.1.9                 | Q | Q | Q     | Q    | Q  | Q   | Q | Q | FFH                      |                                           |
| PWMD0         | 7F9DH   | 10.6.1.10                | Q | Q | Q     | Q    | Q  | Q   | Q | Ø | FFH                      |                                           |
| PWMD1         | 7F9EH   | 10.6.1.11                | Q | Q | Q     | Q    | Q  | Q   | Q | Q | FFH                      |                                           |
| PWMD2         | 7F9FH   | 10.6.1.12                | Q | Q | Q     | Q    | Q  | Q   | Q | Ø | FFH                      |                                           |
| PWMCR         | 7F96H   | 10.6.1.13                | Q | Q | Q     | Q    | -  | Q   | Q | Ø | 0000x000b                |                                           |
| PWM555CR1     | 7F21H   | 10.6.1.14                | - | Q | Q     | R    | Q  | Q   | Q | Q | x00p0000b                |                                           |

#### TABLE 3-14: PWM MMCRs References

T3-14.0 1320

1. All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).

### TABLE 3-15: SMBus MMCRs References

|               |         |                          |   | E | Bit A | lcce | ess ' | Тур | е |   |                          |                                           |
|---------------|---------|--------------------------|---|---|-------|------|-------|-----|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | З     | 2   | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| SMCR0         | 7F31H   | 13.5.1                   | Q | Q | Q     | Q    | Q     | Q   | Q | Q | 00H                      | Q: Read and Write                         |
| SMCR1         | 7F67H   | 13.5.2                   | Q | Q | Q     | Q    | Q     | Q   | Q | Q | 00H                      | R: Read Only                              |
| SMSR0         | 7F32H   | 13.5.3                   | Q | Q | Q     | Q    | R     | R   | R | R | 00H                      | W: Write Only                             |
| SMSR1         | 7F68H   | 13.5.4                   | Q | Q | Q     | Q    | R     | R   | R | R | 00H                      | -: Reserved Bit<br>x: Indeterminate Value |
| SAR0          | 7F33H   | 13.6.1                   | Q | Q | Q     | Q    | Q     | Q   | Q | - | 000000xb                 | p: Pass through pin state                 |
| SAR1          | 7F69H   | 13.6.2                   | Q | Q | Q     | Q    | Q     | Q   | Q | - | 000000xb                 | P                                         |
| SDSR0         | 7F34H   | 13.6.3                   | Q | Q | Q     | Q    | Q     | Q   | Q | Q | 00H                      |                                           |
| SDSR1         | 7F6AH   | 13.6.4                   | Q | Q | Q     | Q    | Q     | Q   | Q | Q | 00H                      |                                           |
| SLSR          | 7F88H   | 13.7.2                   | - | - | R     | R    | R     | R   | R | R | xxppppppb                |                                           |
| SSCR          | 7F89H   | 13.7.1                   | Q | Q | -     | -    | -     | Q   | Q | Q | 00xxx001b                |                                           |

T3-15.0 1320



# TABLE 3-16: PS/2 MMCRs References

|               |         |                          |   |   | Bit / | Acce | ess 1 | Гуре |   |   |                          |                                           |
|---------------|---------|--------------------------|---|---|-------|------|-------|------|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3     | 2    | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| PS2TX0        | 7F41H   | 14.4.1.1                 | W | W | W     | W    | W     | W    | W | W | -                        | Q: Read and Write                         |
| PS2TX1        | 7F45H   | 14.4.1.2                 | W | W | W     | W    | W     | W    | W | W | -                        | R: Read Only                              |
| PS2TX2        | 7F49H   | 14.4.1.3                 | W | W | W     | W    | W     | W    | W | W | -                        | W: Write Only                             |
| PS2RCV0       | 7F41H   | 14.4.2.1                 | R | R | R     | R    | R     | R    | R | R | FFH                      | -: Reserved Bit<br>x: Indeterminate Value |
| PS2RCV1       | 7F45H   | 14.4.2.2                 | R | R | R     | R    | R     | R    | R | R | FFH                      |                                           |
| PS2RCV2       | 7F49H   | 14.4.2.3                 | R | R | R     | R    | R     | R    | R | R | FFH                      |                                           |
| PS2CR0        | 7F42H   | 14.4.3.1                 | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 40H                      |                                           |
| PS2CR1        | 7F46H   | 14.4.3.2                 | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 40H                      |                                           |
| PS2CR2        | 7F4AH   | 14.4.3.3                 | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 40H                      |                                           |
| PS2STS0       | 7F43H   | 14.4.4.1                 | R | R | R     | R    | R     | R    | R | R | 50H                      |                                           |
| PS2STS1       | 7F47H   | 14.4.4.2                 | R | R | R     | R    | R     | R    | R | R | 50H                      |                                           |
| PS2STS2       | 7F4BH   | 14.4.3                   | R | R | R     | R    | R     | R    | R | R | 50H                      |                                           |
| APS2STS0      | 7FF7H   | 14.4.4.4                 | R | R | R     | R    | R     | R    | R | R | 50H                      |                                           |
| APS2STS1      | 7FF8H   | 14.4.4.5                 | R | R | R     | R    | R     | R    | R | R | 50H                      |                                           |
| APS2STS2      | 7FF9H   | 14.4.4.6                 | R | R | R     | R    | R     | R    | R | R | 50H                      |                                           |
| PS2TMOUT      | 7F44H   | 14.4.5.1                 | - | - | -     | -    | Q     | Q    | Q | Q | xxxx0000b                | ]                                         |
| PS2STATUS2    | 7F48H   | 14.4.5.2                 | R | R | R     | R    | R     | R    | R | - | 000000xb                 |                                           |

T3-16.0 1320

1. All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).

| TABLE | 3-17: Fan | Tachometer MMCRs Reference | es |
|-------|-----------|----------------------------|----|
|       |           |                            |    |

|               |         |                          |   | E | Bit A | Acce | ess ' | Гуре | 9 |   |                          |                                           |
|---------------|---------|--------------------------|---|---|-------|------|-------|------|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3     | 2    | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| FANCNT1       | 7FBAH   | 15.3.1                   | R | R | R     | R    | R     | R    | R | R | 00H                      | Q: Read and Write                         |
| FANCNT2       | 7FBBH   | 15.3.2                   | R | R | R     | R    | R     | R    | R | R | 00H                      | R: Read Only                              |
| FAN1LD        | 7FBCH   | 15.3.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      | W: Write Only                             |
| FAN2LD        | 7FBDH   | 15.3.4                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      | -: Reserved Bit<br>x: Indeterminate Value |
| FANTIMEBASE   | 7FBEH   | 15.3.5                   | Q | Q | I     | -    | Q     | Q    | Q | Q | 00xx0101b                | x. Indeterminate value                    |

 All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).

|               |         |                          |   |   | Bit A | Acce | ess ' | Туре | Э |   |                          |                                           |
|---------------|---------|--------------------------|---|---|-------|------|-------|------|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3     | 2    | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| ADDRA         | 7F8EH   | 16.2.1                   | R | R | R     | R    | R     | R    | R | R | 00H                      | Q: Read and Write                         |
| ADDRB         | 7F8FH   | 16.2.2                   | R | R | R     | R    | R     | R    | R | R | 00H                      | R: Read Only                              |
| ADDRC         | 7F90H   | 16.2.3                   | R | R | R     | R    | R     | R    | R | R | 00H                      | W: Write Only                             |
| ADDRD         | 7F91H   | 16.2.4                   | R | R | R     | R    | R     | R    | R | R | 00H                      | -: Reserved Bit<br>x: Indeterminate Value |
| ADDRL         | 7F92H   | 16.2.5                   | R | R | R     | R    | R     | R    | R | R | 00H                      | x. Indeterminate value                    |
| ADCSR         | 7F93H   | 16.2.6                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
|               |         | ·                        |   |   |       |      |       |      |   |   |                          | T3-18.0 1320                              |

#### TABLE 3-18: ADC MMCRs References



#### TABLE 3-19: DAC MMCRs References

|               |         |                          |   | E | Bit A | Acce | ess <sup>-</sup> | Гуре | Э |   |                          |                                           |
|---------------|---------|--------------------------|---|---|-------|------|------------------|------|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3                | 2    | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| DACDAT0       | 7F4CH   | 17.2.1                   | Q | Ø | Q     | Q    | Q                | Q    | Q | Q | 00H                      | Q: Read and Write                         |
| DACDAT1       | 7F4DH   | 17.2.2                   | Q | Ø | Q     | Q    | Q                | Q    | Q | Q | 00H                      | R: Read Only                              |
| DACDAT2       | 7F4EH   | 17.2.3                   | Q | Q | Q     | Q    | Q                | Q    | Q | Q | 00H                      | W: Write Only                             |
| DACDAT3       | 7F4FH   | 17.2.4                   | Q | Ø | Q     | Q    | Q                | Q    | Q | Q | 00H                      | -: Reserved Bit<br>x: Indeterminate Value |
| DACCTRL       | 7F50H   | 17.2.5                   | 1 | - | ŀ     | Q    | Q                | Q    | Q | Q | xxx00000b                | x. Indeterminate value                    |

T3-19.0 1320

1. All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).

TABLE 3-20: KBC Host Interface MMCRs References

|               |         |                          |   | I | Bit A | Acce | ss | Туре | e |   |                          |                                           |
|---------------|---------|--------------------------|---|---|-------|------|----|------|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3  | 2    | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| KBCDATA       | 7FF1H   | 18.2.1                   | Q | Q | Q     | Q    | Q  | Q    | Q | Q | 00H                      | Q: Read and Write                         |
| KBCSTS        | 7FF2H   | 18.2.2                   | Q | Q | Q     | Q    | R  | Q    | R | R | 00H                      | R: Read Only                              |
| AUXDATA       | 7FFAH   | 18.2.3                   | Q | Q | Q     | Q    | Q  | Q    | Q | Q | 00H                      | W: Write Only                             |
| KBDCFG        | 7FF4H   | 18.2.4                   | Q | - | Q     | Q    | -  | Q    | Q | - | 0x00x00xb                | -: Reserved Bit<br>x: Indeterminate Value |
| PCOBF         | 7FFDH   | 18.2.5                   | - | I | -     | -    | -  | -    | 1 | Q | xxxxxxx0b                | x. Indeterminate value                    |
| KEYSCAN       | 7F04H   | 18.3.1                   | R | Q | Q     | Q    | Q  | Q    | Q | Q | 20H                      |                                           |
|               | •       | •                        | • |   |       | •    | -  | •    |   |   |                          | T3-20.0 1320                              |

1. All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).

#### TABLE 3-21: GA20 Control MMCRs References

|               |         |                          |   | I | Bit A | Acce | ess | Туре | e |   |                          |                        |
|---------------|---------|--------------------------|---|---|-------|------|-----|------|---|---|--------------------------|------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3   | 2    | 1 | 0 | Reset Value <sup>1</sup> | Кеу                    |
| GA20          | 7FFBH   | 19.2.1                   | - | - | -     | -    | Q   | Q    | - | Q | xxxx00x1b                | Q: Read and Write      |
| SETGA20       | 7FFEH   | 19.2.2                   | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      | -: Reserved Bit        |
| RSTGA20       | 7FFFH   | 19.2.3                   | Q | Q | Q     | Q    | Q   | Q    | Q | Q | 00H                      | x: Indeterminate Value |
|               |         | ·                        |   |   |       |      |     |      |   |   |                          | T3-21.0 1320           |

 All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).

|  | TABLE | 3-22: ACPI I | EC Interface | <b>MMCRs</b> | References |
|--|-------|--------------|--------------|--------------|------------|
|--|-------|--------------|--------------|--------------|------------|

|               |         |                          |   | E | Bit A | Acce | ss ' | Гуре | 9 |   |                          |                                           |
|---------------|---------|--------------------------|---|---|-------|------|------|------|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3    | 2    | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| ECIDATA       | 7F53H   | 20.2.1                   | Q | Q | Q     | Q    | Q    | Q    | Q | Q | 00H                      | Q: Read and Write                         |
| ECIDATA1      | 7F80H   | 20.2.2                   | Q | Q | Q     | Q    | Q    | Ø    | Q | Q | 00H                      | R: Read Only                              |
| ECISTS        | 7F54H   | 20.2.3                   | Q | Q | Q     | Q    | R    | Q    | R | R | 00H                      | W: Write Only                             |
| ECISTS1       | 7F81H   | 20.2.4                   | Q | Q | Q     | Q    | R    | Q    | R | R | 00H                      | -: Reserved Bit<br>x: Indeterminate Value |
| ECICFG        | 7F51H   | 20.3.1                   | - | - | Q     | Q    | Q    | Q    | Q | Q | xx000000b                | A. Indeterminate value                    |
| ECICFG1       | 7F52H   | 20.3.2                   | - | - | Q     | Q    | Q    | Q    | Q | Q | xx000000b                |                                           |

T3-22.0 1320



# TABLE 3-23: MailBox MMCRs References

|               |         |                          |   |   | Bit A | Acce | ess ' | Гуре | e |   |                          |                                           |
|---------------|---------|--------------------------|---|---|-------|------|-------|------|---|---|--------------------------|-------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3     | 2    | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                       |
| MBX0          | 7F08H   | 21.1.1                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      | Q: Read and Write                         |
| MBX1          | 7F09H   | 21.1.2                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      | R: Read Only                              |
| MBX2          | 7F0AH   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      | W: Write Only                             |
| MBX3          | 7F0BH   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      | -: Reserved Bit<br>x: Indeterminate Value |
| MBX4          | 7F0CH   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX5          | 7F0DH   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX6          | 7F0EH   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX7          | 7F0FH   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX8          | 7F10H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX9          | 7F11H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBXA          | 7F12H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBXB          | 7F13H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBXC          | 7F14H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBXD          | 7F15H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBXE          | 7F16H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBXF          | 7F17H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX10         | 7F70H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX11         | 7F71H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX12         | 7F72H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX13         | 7F73H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX14         | 7F74H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX15         | 7F75H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX16         | 7F76H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX17         | 7F77H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX18         | 7F78H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX19         | 7F79H   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX1A         | 7F7AH   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX1B         | 7F7BH   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX1C         | 7F7CH   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX1D         | 7F7DH   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX1E         | 7F7EH   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX1F         | 7F7FH   | 21.1.3                   | Q | Q | Q     | Q    | Q     | Q    | Q | Q | 00H                      |                                           |
| MBX94         | -       | 21.2.1                   | R | R | -     | Q    | R     | -    | - | Q | 00x00xx0b                | ]                                         |
| MBX96         | -       | 21.2.2                   | - | - | -     | -    | R     | -    | - | - | xxxx0xxxb                |                                           |
| MBX97         | -       | 21.2.3                   | - | - | -     | -    | Q     | -    | - | - | xxxx0xxxb                |                                           |

T3-23.0 1320



|               |         |                          | Bit Access Type |   |   |   |   | Тур | е |   |                          |                                                                        |
|---------------|---------|--------------------------|-----------------|---|---|---|---|-----|---|---|--------------------------|------------------------------------------------------------------------|
| Register Name | Address | <b>Reference Section</b> | 7               | 6 | 5 | 4 | 3 | 2   | 1 | 0 | Reset Value <sup>1</sup> | Кеу                                                                    |
| LPCMON        | 7F8AH   | 23.1.1                   | Q               | Q | Q | 1 | 1 | I   | Q | R | 001xxx0pb                | Q: Read and Write                                                      |
| CFGINDEX      | 7F8CH   | 23.1.2                   | Q               | Q | Q | Q | Q | Q   | Q | Q | 00H                      | R: Read Only                                                           |
| CFGDATA       | 7F8DH   | 23.1.3                   | Q               | Q | Q | Q | Q | Q   | Q | Q | 00H                      | -: Reserved Bit<br>x: Indeterminate Value<br>p: Pass through pin state |

#### TABLE 3-24: Configuration MMCRs References

T3-24.0 1320

1. All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).

TABLE 3-25: Miscellaneous MMCRs References

|                        |         |                          |   | E | Bit A | Acce | ess ' | Тур | e |   |                                       |                        |
|------------------------|---------|--------------------------|---|---|-------|------|-------|-----|---|---|---------------------------------------|------------------------|
| Register Name          | Address | <b>Reference Section</b> | 7 | 6 | 5     | 4    | 3     | 2   | 1 | 0 | Reset Value <sup>1</sup>              | Кеу                    |
| MID                    | 7F05H   | 3.5.2                    | R | R | R     | R    | R     | R   | R | R | BFH                                   | Q: Read and Write      |
| DEVID                  | 7F06H   | 3.5.3                    | R | R | R     | R    | R     | R   | R | R | F0H                                   | R: Read Only           |
| DEVREV                 | 7F07H   | 3.5.4                    | R | R | R     | R    | R     | R   | R | R | 01H                                   | -: Reserved Bit        |
| CLKSRCCON <sup>2</sup> | 7F27H   | 5.3.2.1                  | - | - | Q     | Q    | R     | Q   | Q | R | xx010100b                             | x: Indeterminate Value |
| SRCROM <sup>2</sup>    | 7F28H   | 4.4.1.1                  | 1 | - | -     | 1    | Q     | Q   | Q | Q | x0H                                   |                        |
| RSTCON <sup>2</sup>    | 7F2EH   | 5.2.3.1                  | 1 | - | -     | -    | -     | Q   | Q | Q | xxxxx001b                             |                        |
| SFCS                   | 7FC0H   | 4.4.5.1                  | Q | - | -     | -    | Q     | Q   | R | Q | 0xxx0x <sup>3</sup> 10b               |                        |
| SFCMD                  | 7FC1H   | 4.4.5.2                  | Q | Q | -     | -    | Q     | Q   | Q | Q | 00xx0000b                             |                        |
| SFAL                   | 7FC2H   | 4.4.5.3                  | Q | Q | Q     | Q    | Q     | Q   | Q | Q | 00H                                   |                        |
| SFAH                   | 7FC3H   | 4.4.5.4                  | Q | Q | Q     | Q    | Q     | Q   | Q | Q | 00H                                   |                        |
| SFAX                   | 7FC6H   | 4.4.5.5                  | Q | Q | Q     | Q    | Q     | Q   | Q | Q | 00H                                   |                        |
| SFDL                   | 7FC4H   | 4.4.5.6                  | Q | Q | Q     | Q    | Q     | Q   | Q | Q | 00H                                   |                        |
| SFDH                   | 7FC5H   | 4.4.5.7                  | Q | Q | Q     | Q    | Q     | Q   | Q | Q | 00H                                   |                        |
| SFSEC                  | 7FC7H   | 4.7.1                    | Q | Q | Q     | Q    | Q     | Q   | Q | Q | 00 <sup>4</sup> 0000x <sup>3</sup> 0b |                        |
| LPCSS                  | 7FDFH   | 9.1.9                    | - | - | -     | -    | -     | Q   | Q | Q | xxxxx000b                             |                        |
| PLLM <sup>2</sup>      | 7F35H   | 5.3.2.2                  | - | - | Q     | Q    | Q     | Q   | Q | Q | xx100010b                             |                        |
| PLLPS <sup>2</sup>     | 7F36H   | 5.3.2.3                  | - | - | Q     | Q    | Q     | Q   | Q | Q | xx110010b                             |                        |
| ALPCBC                 | 7F8BH   | 4.8.2                    | Q | - | -     | -    | -     | -   | - | - | 0xxxxxxb                              |                        |

T3-25.0 1320

1. All MMCRs returned to their reset values specified in the charts above after the following reset events: Power-On reset, External reset, Watchdog timer reset, Brown-out reset, 8051 firmware Soft reset, LPC Soft reset, and aLPC Soft reset (see also Section 5.2).

2. These selected MMCRs are also returned to their reset values after the following reset events: 8051 firmware Soft reset, and LPC Soft reset (see also Section 5.2).

3. Bit 2 of SFCS register and Bit 1 of the SFSEC register are affected by reset events as follows: After Power-On Reset, External reset, Watchdog timer reset, Brown-out reset, and aLPC Soft reset SFCS[2] = SFSEC[1] = 0 if ENVR location at address 0FFFH contains 0FFH value SFCS[2] = SFSEC[1] = 1 if ENVR location at address 0FFFH contains any value other than 0FFH After 8051 firmware Soft reset, and LPC Soft reset SFCS[2] is always cleared ('0'), and SFSEC[1] is preserved. These bits are not affected by other reset events.

4. Bit 6 of SFSEC register is reset only by Power-On reset, External reset, Brown-out reset, and LPC Interface reset.



# 3.5.2 JEDEC Registers

# 3.5.2.1 JEDEC Manufacturer ID Register (MID)

| Location |       | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|----------|-------|------|------|------|------|------|------|------|------|
| 7F05H    | Read  | MID7 | MID6 | MID5 | MID4 | MID3 | MID2 | MID1 | MID0 |
|          | Write | -    | -    | -    | -    | -    | -    | -    | -    |
|          | Reset | 1    | 0    | 1    | 1    | 1    | 1    | 1    | 1    |

Symbol

#### Function

Not implemented, reserved for future use.

**Note**: User should not write '1's to reserved bits. The value read from a reserved bit is indeterminate.

### 3.5.2.2 JEDEC Device ID Register (DEVID)

| Location |       | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------|-------|-----|-----|-----|-----|-----|-----|-----|-----|
| 7F06H    | Read  | ID7 | ID6 | ID5 | ID4 | ID3 | ID2 | ID1 | ID0 |
|          | Write | -   | -   | -   | -   | -   | -   | -   | -   |
|          | Reset | 1   | 1   | 1   | 1   | 0   | 0   | 0   | 0   |

Symbol

#### Function

Not implemented, reserved for future use.

**Note**: User should not write '1's to reserved bits. The value read from a reserved bit is indeterminate.

#### 3.5.2.3 Device Revision Register (DEVREV)

| Location |       | 7    | 6                                   | 5    | 4    | 3    | 2    | 1    | 0    |  |  |  |
|----------|-------|------|-------------------------------------|------|------|------|------|------|------|--|--|--|
| 7F07H    | Read  | REV7 | REV6                                | REV5 | REV4 | REV3 | REV2 | REV1 | REV0 |  |  |  |
|          | Write | -    | -                                   | -    | -    | -    | -    | -    | -    |  |  |  |
|          | Reset |      | Device Revision Number <sup>1</sup> |      |      |      |      |      |      |  |  |  |

1. Please contact SST to find out how this number corresponds to the SST79LF008 package markings.

Symbol

#### Function

Not implemented, reserved for future use.

**Note**: User should not write '1's to reserved bits. The value read from a reserved bit is indeterminate.



# 4.0 FLASH MEMORY PROGRAMMING

# 4.1 SuperFlash Memory Overview

The SST79LF008 flash memory is manufactured with SST's proprietary, high-performance SuperFlash technology. The split-gate cell design and thick-oxide tunneling injector attain greater reliability and manufacturability compared with alternative technology approaches. The Super-Flash technology significantly improves the performance and reliability of the flash memory while lowering power consumption.

The SST79LF008 allows flash Write operations (Program or Erase) in-system with a single 3.0-3.6V power supply, and it uses less energy during Erase and Program than alternative flash memory technologies for memory devices. The total energy consumed is a function of the applied voltage, current, and time of application. SuperFlash technology uses less current to program for any voltage range and has a shorter erase time than comparable technologies. This means that the total energy consumed during any Erase or Program operation is less than alternative flash memory technologies.

The SuperFlash technology provides fixed Erase and Program times, independent of the number of the performed Erase/Program cycles. This eliminates the need to calibrate or correlate the system software or hardware to the cumulative number of erase cycles, which is necessary with alternative flash memory technologies whose Erase and Program times increase with accumulated Erase/Program cycles. To protect against inadvertent write, the SST79LF008 provides on-chip write protection. The SST79LF008 flash memory is offered with a typical endurance of 100,000 cycles and data retention of greater than 100 years.

The SST79LF008 flash array is a (512K + 2K) x 16 sector erase, block erase, and word program embedded Super-Flash memory. It is organized as 512K words of Main Flash Memory array plus 2K words of erasable non-volatile registers (ENVR). In addition 1.5K words of user non-volatile registers (UNVR) can be one-time programmed.

### Key Features of SST79LF008 Flash Memory:

- SuperFlash Technology
- Organized as (512K Main array + 2K ENVR) x16
- Single Voltage Read/Write Operations
- Endurance: 100,000 Cycles (typical)
- Greater than 100 years Data Retention
- Main array and ENVR write and read protection with a lock down/open after reset only option
- Uniform 2K Word sectors
- Uniform 32K Word blocks
- Sector-/Block-Erase Capability
- Fast Sector-/Block-Erase Time:
  - 55 ms typical
  - 60 ms max
- Fast Word-Program Time:
  - 15 µs typical
  - 60 µs max



Mobile Platform Controller 8 Mbit LPC Firmware Flash SST79LF008

Advance Information

# 4.2 Flash Memory Map

The map of SST79LF008 main flash memory array is shown in Figure 4-1. It includes a total 1 MByte (8 Mbit) flash memory space. A maximum of 128 KByte KBC firmware block can be located in the lower part of flash memory to store the 8051-specific keyboard and embedded controller code. The other flash memory area can be used to store the system BIOS related code and data. See Section 7.0 for the details on mapping SST79LF008 flash memory into the system LPC interface address space.



FIGURE 4-1: SST79LF008 Flash Memory Map

# 4.2.1 ENVR / UNVR Address Space

The maps of ENVR and UNVR address spaces are shown in tables below.

#### TABLE4-1: ENVR Address Space

| Address   | Contents                          |
|-----------|-----------------------------------|
| FFFH      | EnableBoot Byte (see Section 4.5) |
| 000H-FFEH | Erasable NVR for user             |

T4-1.0 1320

#### TABLE 4-2: UNVR Address Space

| Address   | Contents            |
|-----------|---------------------|
| 000H-BFFH | 3K OTP for User NVR |

T4-2.0 1320

# 4.2.2 Programming Modes

The SST79LF008 internal flash memory (including ENVR and UNVR spaces) can be programmed through a Shared ROM Interface using the following three methods:

- In-Application Programming Mode (8051 controlled)
- Remote aLPC Programming Mode (aLPC Host controlled)
- In-system LPC Programming Mode (LPC Host controlled)

The first two modes are described in this section. For LPC programming mode, see Section 7.0.



# 4.3 Shared ROM Interface

The SST79LF008 Shared ROM Interface (SRI) provides LPC Host, alternate LPC (aLPC) Host and the 8051 MCU with access to the entire 1 MByte of main Flash memory array as well as to ENVR and UNVR areas. See Figure 4-2.



FIGURE 4-2: Shared ROM Interface

Both LPC and aLPC Hosts access flash memory via the internal LPC bus interface unit (see details on switching bus control between LPC Host and aLPC Host in Section 4.8). The aLPC Host flash access is exclusive as 8051 is forced into reset state while aLPC mode is enabled. The LPC Host and 8051 may access flash memory concurrently. For LPC Host read operations the arbitration between LPC Host and 8051 is completely handled by SRI hardware. For LPC Host program/erase operation flash memory access arbitration must be implemented in software via one of the following mechanisms:

- 1. 8051 firmware turns over the flash bus to the LPC Host by setting HOST\_ACCESS bit in SFCS register, see Section 4.4.5, In this case 8051 firmware must run from the Scratch ROM, described in Section 4.4.1, just before and while the flash bus is released to the LPC Host.
- 2. 8051 firmware enters Idle mode, which allows the LPC Host software to take over the flash bus by setting the STP\_CLK bit in MBX94 register, described in Section 21.2. In this case 8051 firmware can run from flash before entering Idle mode provided the LPC Host does not update the respective flash locations.

For any mechanism above, the LPC Host software can confirm the bus turn around by checking the HOSTFLASH bit in MBX94 register. See Section 21.2.

3. 8051 firmware enables LPC Soft reset via LPC-MON register, detailed in Section 23.1, which allows the LPC Host to take over the flash bus by sending a Force LPC Soft Reset command, detailed in Section 7.3. In this case 8051 will be kept in reset state and 8051 firmware will not run until the LPC Host sends a Release LPC Soft Reset command, which re-starts 8051 code execution. As KBC operation is aborted and then restarted, this mechanism is not recommended for LPC Host program/erase access, unless flash memory is blank or corrupted.



# 4.4 In-Application Programming Mode

During In-Application programming (IAP), the 8051 executes instructions from the scratch ROM, which is a portion of XRAM mapped to the top or bottom of the first 64 KByte (Block0) in the 8051 program space. The flash control registers SFCS, SFCMD, SFAL, SFAH, SFDL, and SFDH located among the memory-mapped registers, control and monitor the device's erase and program operations.

# 4.4.1 Scratch ROM Mapping Control

The IAP code must be executed from 8051 program memory space that is not on the flash. For this purpose the SST79LF008 allows a section of on-chip XRAM to be mapped to 8051 program space. The memory-mapped register SCRROM, described below, controls the mapping of XRAM to 8051 program address space. Mapping can affect the entire 2K expanded RAM, or only part of it, as indicated by SCRSIZE field. Table 4.3 details scratch ROM mapping to 8051 program space. See also Figures 3-2 to 3-6.

# 4.4.1.1 Scratch ROM Control Register (SCRROM)

| Location |              | 7 | 6                                                                                                                                                                 | 5                                    | 4         | 3        | 2        | 1      | 0     |  |  |  |  |
|----------|--------------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-----------|----------|----------|--------|-------|--|--|--|--|
| 7F28H    | Read/Write   | - | -                                                                                                                                                                 | -                                    | -         | SCRSIZE1 | SCRSIZE0 | SCRPOS | SCREN |  |  |  |  |
|          | Reset        | Х | Х                                                                                                                                                                 | Х                                    | Х         | 0        | 0        | 0      | 0     |  |  |  |  |
|          | Symbol       |   | Functior                                                                                                                                                          | ı                                    |           |          |          |        |       |  |  |  |  |
|          | -            |   | Not implemented, reserved for future use.<br><b>Note</b> : User should not write '1's to reserved bits. The value read from a reserved bit is indeterminate.      |                                      |           |          |          |        |       |  |  |  |  |
|          | х            |   | Not defin                                                                                                                                                         | ed                                   |           |          |          |        |       |  |  |  |  |
|          | SCRSIZE[1:0] |   | Scratch ROM size<br>00: 256 Bytes<br>01: 512 Bytes<br>10: 1024 Bytes<br>11: 2048 Bytes<br>Scratch ROM position<br>1: Map to Block0 top<br>0: Map to Block0 bottom |                                      |           |          |          |        |       |  |  |  |  |
|          | SCRPOS       |   |                                                                                                                                                                   |                                      |           |          |          |        |       |  |  |  |  |
|          | SCREN        |   | 1: Enable                                                                                                                                                         | ROM mappir<br>e mapping<br>e mapping | ng enable |          |          |        |       |  |  |  |  |

#### TABLE 4-3: Scratch ROM Mapping

| SCREN | SCRPOS | SCRSIZE[1:0] | XRAM Section Address | Program Space Address |
|-------|--------|--------------|----------------------|-----------------------|
| 0     | Х      | XX           | 000H - 7FFH          | No Mapping            |
| 1     | 0      | 00           | 700H - 7FFH          | 0000H - 00FFH         |
| 1     | 0      | 01           | 600H - 7FFH          | 0000H - 01FFH         |
| 1     | 0      | 10           | 400H - 7FFH          | 0000H - 03FFH         |
| 1     | 0      | 11           | 000H - 7FFH          | 0000H - 07FFH         |
| 1     | 1      | 00           | 700H - 07FFH         | FF00H - FFFFH         |
| 1     | 1      | 01           | 600H - 7FFH          | FE00H - FFFFH         |
| 1     | 1      | 10           | 400H - 7FFH          | FC00H - FFFFH         |
| 1     | 1      | 11           | 000H - 7FFH          | F800H - FFFFH         |

T4-3.0 1320



### 4.4.2 IAP Mode Control

The IAP enable bit, SFCS[7], enables in-application programming mode. Until this bit is set, all flash programming IAP commands will be ignored.

Table 4-4 contains the In-Application Programming commands that can be used when IAP mode is enabled. All IAP commands should be executed from the Scratch ROM by writing the command code to SFCMD register after address and data registers are properly loaded, see Figures 4-3 to 4-6. The command codes not listed in the table are reserved.

The same commands are used to access either main 1MByte flash array, or 4 KByte flash ENVR, or 3 KByte OTP UNVR. The selection of the target memory area is controlled by bits SFCMD[7:6].

| Operation             | SFCMD[3:0]                | SFDH[7:0]       | SFDL[7:0]       | SFAX[7:0]       | SFAH[7:0]       | SFAL[7:0]       |
|-----------------------|---------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| Reserved <sup>2</sup> | 0000b,<br>1110b           | X <sup>3</sup>  | х               | х               | х               | х               |
| Sector-Erase          | 0001b                     | Х               | Х               | AX <sup>4</sup> | AH⁵             | Х               |
| Block-Erase           | 0010b                     | Х               | Х               | AX <sup>4</sup> | AH⁵             | Х               |
| Word- Program         | 0011b                     | DH <sup>6</sup> | DL <sup>6</sup> | AX <sup>4</sup> | AH <sup>5</sup> | AL <sup>7</sup> |
| Erase-Suspend         | 0100b                     | Х               | Х               | Х               | Х               | Х               |
| Erase-Resume          | 0101b                     | Х               | Х               | Х               | Х               | Х               |
| Word-Read             | 1111b                     | DH <sup>6</sup> | DL <sup>6</sup> | AX <sup>4</sup> | AH⁵             | AL <sup>7</sup> |
| No Operation          | Remaining<br>Combinations | X <sup>3</sup>  | х               | Х               | х               | Х               |

 TABLE
 4-4: IAP Commands<sup>1</sup> for SST79LF008

1. SFCS[7] = 1 enables IAP commands; SFCS[7] = 0 disables IAP commands.

2. Do not use reserved values.

3. X = "Don't care"

4. AX = Word Address most significant order byte (SFAX[7:3] = 0, SFAX[2:0] = Word address bits 18:16).

5. AH = Word Address high order byte (SFAH[7:0] = Word address bits 15:8).

6. DH = Data high byte (input or output); DL = Data low byte (input or output).

7. AL = Word Address low order byte (SFAL[7:0] = Word address bits 7:0).

# 4.4.3 Address Selection for IAP Commands

Only word access is supported in IAP mode. Three address registers (SFAX, SFAH and SFAL) are provided to specify 24-bit word address for any individual word location. Only 19 bits of these registers are significant for access to 512 KWord main flash array, bits 23:19 (SFAX[7:3]) must be always 0. Sixteen 32 KWord blocks in the main flash array can be erased independently. There are 16 sectors of 2 KWord in each block, and each sector can also be erased independently. In addition the 2 KWord ENVR flash sector can be erased in IAP mode. For block or sector selection SFAX, SFAH, and SFAL registers should be loaded with any valid word address within the respective block or sector.

T4-4.0 1320



# 4.4.4 IAP Mode Commands Description

### 4.4.4.1 No Operation

The No Operation command causes the flash controller to do nothing.

### 4.4.4.2 Sector-Erase

The Sector-Erase command erases all bytes in a sector. The sector size is 2 KWord (4 KByte). The selection of the sector to be erased is determined by the contents of SFAX and SFAH registers. For example, to erase sector FF000H-FFFFFH of the main flash array the following settings should be used.



FIGURE 4-3: IAP Sector-Erase

### 4.4.4.3 Block-Erase

The Block-Erase command erases all bytes in a 32 KWord (64 KByte) memory block. The selection of the block to be erased is determined by the contents of SFAX and SFAH registers. For example, to erase block F0000H-FFFFFH of the main flash array the following settings should be used.







### 4.4.4.4 Word-Program

The Word-Program command programs data into a single word location in the flash memory. The word address is determined by the contents of SFAX, SFAH and SFAL registers. The data to be programmed is stored in registers SFDH (high byte) and SFDL (low byte). For example, to program word data to the main flash array at word address 7F801H (which results in storing high byte word data at byte address FF003H, and low byte word data at byte address FF002H) the following settings should be used.



FIGURE 4-5: IAP Word-Program

# 4.4.4.5 Erase-Suspend

The Erase-Suspend command allows a Sector-Erase or Block-Erase operation interruption in order to read or program data into another block of memory. Once the Erase-Suspend command is executed, the device will suspend the on-going erase operation.

After a successful Erase-Suspend, a Word-Read or Word-Program command can be issued to read from or write to a different sector/block of flash memory than the one suspended. If a Word-Read command is issued to an address within the suspended sector or block, the read operation may return invalid data. If a Word-Program command is issued to an address within the suspended memory area, the command is acknowledged but rejected.

Suspended operations cannot be nested. That is, the system needs to complete/resume any previously suspended operation before a new operation can be suspended.



Advance Information

# 4.4.4.6 Erase-Resume

The Erase-Resume command resumes the erase process in the suspended sector or block. After the Erase-Resume command is issued, the device will resume the erase process. Erase cannot be resumed until the Word-Read or Word-Program operation already in progress has been completed.

# 4.4.4.7 Word-Read

The Word-Read command allows the user to verify that the device has correctly performed an Erase or Program command. Word-Read returns the data word in registers SFDH (high byte) and SFDL (low byte) if the command is successful. The user must check if the previous flash operation has been fully completed before issuing a Word-Read. Word-Read command execution time is short enough that there is no need to poll for command completion. The address is determined by the contents of SFAX, SFAH and SFAL registers. For example, to read word FF003H:FF002H of the main flash array the following settings should be used.



FIGURE 4-6: IAP Word-Read



# 4.4.5 SuperFlash Control and Status Registers

# 4.4.5.1 SuperFlash Control and Status Register (SFCS)

| Location |                                                                                                                                                                                                                                            | 7                                                                                                         | 6  | 5                                                                                                                                                                                                                                                                                                                                                                                                                     | 4                                              | 3             | 2            | 1               | 0                 |  |  |  |  |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|---------------|--------------|-----------------|-------------------|--|--|--|--|
| 7FC0H    | Read                                                                                                                                                                                                                                       | IAPEN                                                                                                     | -  | -                                                                                                                                                                                                                                                                                                                                                                                                                     | -                                              | SOFTRST       | OVERLAY      | FLASH_RDY       | HOST_ACCESS       |  |  |  |  |
|          | Write                                                                                                                                                                                                                                      |                                                                                                           |    |                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                |               |              | -               |                   |  |  |  |  |
|          | Reset                                                                                                                                                                                                                                      | 0                                                                                                         | Х  | Х                                                                                                                                                                                                                                                                                                                                                                                                                     | Х                                              | 0             | Х            | 1               | 0                 |  |  |  |  |
|          | Symbol                                                                                                                                                                                                                                     |                                                                                                           | Fi | Inction                                                                                                                                                                                                                                                                                                                                                                                                               |                                                |               |              |                 |                   |  |  |  |  |
|          | -                                                                                                                                                                                                                                          |                                                                                                           |    |                                                                                                                                                                                                                                                                                                                                                                                                                       | ed, reserved fo                                | or future use | ).           |                 |                   |  |  |  |  |
|          |                                                                                                                                                                                                                                            |                                                                                                           | No | •                                                                                                                                                                                                                                                                                                                                                                                                                     | uld not write '1                               |               |              | value read fro  | om a reserved bit |  |  |  |  |
|          | Х                                                                                                                                                                                                                                          |                                                                                                           |    | Not defined                                                                                                                                                                                                                                                                                                                                                                                                           |                                                |               |              |                 |                   |  |  |  |  |
|          | IAPEN 8051 controlled IAP mode Enable bit<br>1: Enable IAP mode<br>0: Disable IAP mode<br>This bit can be set by the 8051 firmware only while it is running<br>ROM. The firmware must not restart running from flash until thi             |                                                                                                           |    |                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                |               |              |                 |                   |  |  |  |  |
|          | SOFTRS                                                                                                                                                                                                                                     | ST                                                                                                        | A  |                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                | •             | erate an 80  | 51 soft reset ( | see Section 5.2   |  |  |  |  |
|          | OVERLAY       BootRom Overlay bit         1: BootRom (0F000H? 0FFFH) is mapped to bottom 4 KByte sector in 80 program space (00000H - 00FFFH),         0: BootRom (0F000H - 0FFFFH) is NOT mapped to bottom 4 KByte sector i program space |                                                                                                           |    |                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                |               |              |                 |                   |  |  |  |  |
|          |                                                                                                                                                                                                                                            |                                                                                                           | Th | ie reset valu                                                                                                                                                                                                                                                                                                                                                                                                         | e of this bit is                               | determine     | ed as follow | NS.             |                   |  |  |  |  |
|          |                                                                                                                                                                                                                                            |                                                                                                           | 1. | <ol> <li>After Power On Reset, External pin reset, Watchdog timer reset, Brown-<br/>out reset         OVERLAY = 0 if the ENVR location at address 0FFFH contains 0FFH         value.         OVERLAY = 1 if the ENVR location at address 0FFFH contains any value         other         than 0FFH</li> </ol>                                                                                                          |                                                |               |              |                 |                   |  |  |  |  |
|          |                                                                                                                                                                                                                                            |                                                                                                           | 2. | After 8051 s<br>always.                                                                                                                                                                                                                                                                                                                                                                                               | soft reset, LP                                 | C soft rese   | et, and aLF  | PC soft reset,  | , OVERLAY = 0     |  |  |  |  |
|          |                                                                                                                                                                                                                                            |                                                                                                           | 3. | <ol> <li>Once the byte at location 0FFFH of ENVR is programmed, it can only<br/>restored by ENVR erase, but software can always change the value of<br/>OVERLAY bit at run time without the need of ENVR erase. OVERLAY<br/>affects only flash memory access addressed via 8051 program counte<br/>(PC). It does not affect physical addresses used in IAP mode for flash<br/>memory programming commands.</li> </ol> |                                                |               |              |                 |                   |  |  |  |  |
|          | FLASH_                                                                                                                                                                                                                                     | RDY                                                                                                       | 1: | Ready - IAP                                                                                                                                                                                                                                                                                                                                                                                                           | am or erase co<br>command is c<br>ommand is in | ompleted      | IAP mode     |                 |                   |  |  |  |  |
|          | HOST_A                                                                                                                                                                                                                                     | ST_ACCESSFlash bus ownership control bit.1: 8051 released flash bus to LPC Host0: 8051 owns the flash bus |    |                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                |               |              |                 |                   |  |  |  |  |



# 4.4.5.2 SuperFlash Command Register (SFCMD)

|      |                | 7       | 6                                                                                        | 5              | 4              | 3               | 2              | 1             | 0          |  |  |  |
|------|----------------|---------|------------------------------------------------------------------------------------------|----------------|----------------|-----------------|----------------|---------------|------------|--|--|--|
| FC1H | Read/<br>Write | UNVRSEL | ENVRSEL                                                                                  | -              | -              | FCM3            | FCM2           | FCM1          | FCM0       |  |  |  |
|      | Reset          | 0       | 0                                                                                        | Х              | Х              | 0               | 0              | 0             | 0          |  |  |  |
| S    | Symbol         |         | Fund                                                                                     | tion           |                |                 |                |               |            |  |  |  |
| _    | -              |         | Not ir                                                                                   | nplemented     | l, reserved fo | r future use.   |                |               |            |  |  |  |
|      |                |         | Note                                                                                     | •              |                | s to reserved   | bits. The valu | e read from a | a reserved |  |  |  |
| Х    | <              |         | Not d                                                                                    | efined         |                |                 |                |               |            |  |  |  |
| ι    | JNVRSE         | EL      | Select UNVR as target for IAP command.                                                   |                |                |                 |                |               |            |  |  |  |
| E    | ENVRSE         | EL      | Selec                                                                                    | t ENVR as      | target for IAF | command.        |                |               |            |  |  |  |
|      |                |         |                                                                                          |                | U              |                 |                |               |            |  |  |  |
|      |                |         | SFCMD[7                                                                                  | :6] C          | peration       |                 |                |               |            |  |  |  |
|      |                |         | 1X                                                                                       |                | Select UN      | /R <sup>1</sup> |                |               |            |  |  |  |
|      |                |         | 01                                                                                       |                | Select EN\     | /R <sup>2</sup> |                |               |            |  |  |  |
|      |                |         | 00 Select Main flash array<br>1. Valid address for 3 KB UNVR area is from 0000H to 0BFFH |                |                |                 |                |               |            |  |  |  |
|      |                |         | <ol> <li>Valid addres</li> <li>Valid addres</li> </ol>                                   |                |                |                 |                |               |            |  |  |  |
|      |                |         |                                                                                          |                |                |                 |                |               |            |  |  |  |
| F    | -CM[3:0        | ]       | IAP n                                                                                    | node flash c   | command        |                 |                |               |            |  |  |  |
|      |                |         | SFCMD[3                                                                                  | :0] C          | peration       |                 |                |               |            |  |  |  |
|      |                |         | 0000                                                                                     |                | No Operati     | on              |                |               |            |  |  |  |
|      |                |         | 0001                                                                                     |                | Sector-Era     |                 |                |               |            |  |  |  |
|      |                |         | 0010                                                                                     |                | Block-Eras     | e               |                |               |            |  |  |  |
|      |                |         | 0011                                                                                     |                | Word-Prog      |                 |                |               |            |  |  |  |
|      |                |         | 0100                                                                                     |                | Erase-Sus      | pend            |                |               |            |  |  |  |
|      |                |         | 0101                                                                                     | 1 Erase-Resume |                |                 |                |               |            |  |  |  |
|      |                |         | 1111                                                                                     |                | Word-Read      | k               |                |               |            |  |  |  |

# 4.4.5.3 SuperFlash Address Register (SFAL)

| Location |                | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| 7FC2H    | Read/<br>Write | SFAL7 | SFAL6 | SFAL5 | SFAL4 | SFAL3 | SFAL2 | SFAL1 | SFAL0 |
|          | Reset          | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

# Symbol

Function

SFAL[7:0]

Flash Word Address low order byte.



### 4.4.5.4 SuperFlash Address Register (SFAH)

| Location    |                    | 7          | 6            | 5          | 4             | 3          | 2          | 1          | 0          |
|-------------|--------------------|------------|--------------|------------|---------------|------------|------------|------------|------------|
| 7FC3H       | Read/<br>Write     | SFAH7      | SFAH6        | SFAH5      | SFAH4         | SFAH3      | SFAH2      | SFAH1      | SFAH0      |
|             | Reset              | 0          | 0            | 0          | 0             | 0          | 0          | 0          | 0          |
|             | Symbol<br>SFAH[7:0 | -          |              | Word Addre | ess high orde | r byte.    |            |            |            |
| 4.4.5.5 Sup | berFlash           | Address F  | Register (SF | AX)        |               |            |            |            |            |
| Location    |                    | 7          | 6            | 5          | 4             | 3          | 2          | 1          | 0          |
|             |                    |            |              |            |               |            |            |            |            |
| 7FC6H       | Read/<br>Write     | SFAX7      | SFAX6        | SFAX5      | SFAX4         | SFAX3      | SFAX2      | SFAX1      | SFAX0      |
| 7FC6H       |                    | SFAX7<br>0 | SFAX6<br>0   | SFAX5<br>0 | SFAX4<br>0    | SFAX3<br>0 | SFAX2<br>0 | SFAX1<br>0 | SFAX0<br>0 |

Symbol

Function

SFAX[7:0]

Flash Word Address most significant order byte.

**Note:**SFAX, SFAH and SFAL registers are cascaded to form a linear Word Address of the entire 8 Mbit on-chip flash memory (Word Address = (Byte Address)/2).

# 4.4.5.6 SuperFlash Data Low Register (SFDL)

| Location |                | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| 7FC4H    | Read/<br>Write | SFDL7 | SFDL6 | SFDL5 | SFDL4 | SFDL3 | SFDL2 | SFDL1 | SFDL0 |
|          | Reset          | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

Symbol SFDL[7:0]

### Function

Flash data low byte. For read flash command reading this register returns the low byte of word data from the flash. For write flash command SFDL contains the low byte of word data to be programmed. (SST79LF008 only supports word-wide access in IAP mode).

#### 4.4.5.7 SuperFlash Data High Register (SFDH)

| Location |                | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| 7FC5H    | Read/<br>Write | SFDH7 | SFDH6 | SFDH5 | SFDH4 | SFDH3 | SFDH2 | SFDH1 | SFDH0 |
|          | Reset          | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

Symbol SFDH[7:0]

# Function

Flash data high byte. For read flash command reading this register returns the high byte of word data from the flash. For write flash command SFDH contain the high byte of word data to be programmed. (SST79LF008 only supports word-wide access in IAP mode).



# 4.5 BootRom Area

BootRom area physically occupies top 4KByte of flash memory Block0 at addresses from 0F000H to 0FFFFH. Bit 2 OVERLAY of the SFCS register controls logical mapping of the BootRom area.

When OVERLAY = 1, BootRom is enabled to overlay the bottom 4 KByte address of flash memory. The overlay mode only affects the memory access addressed via 8051 program counter (PC). It does not affect the physical addresses of flash memory locations used for memory access by flash programming commands. When OVER-LAY = 0, BootRom overlay mode is disabled. The OVER-LAY bit can be altered at run-time and any change takes effect immediately. Hence, it is recommended that the OVERLAY bit be changed by the code outside the overlapped bottom 4 KByte address range.

The Power-on reset, Brown-out reset, External pin reset, and Watchdog timer reset will set/clear OVERLAY bit according to the EnableBoot byte in ENVR as shown in Table 4-5.

8051 soft reset (via SFCS.3 bit), LPC and aLPC soft resets clear OVERLAY bit regardless of ENVR state and re-start KBC firmware always from 0000H physical address.

EnableBoot is a non-volatile flash byte, and it is located at address 0FFFH (last byte) of ENVR. After ENVR is erased, the default value is 0FFH. This non-volatile byte can be programmed by IAP command, or via LPC, or aLPC bus. Since SST79LF008 only supports word program, in order to program EnableBoot byte, the entire word 0FFFH:0FFEH has to be updated.

| EnableBoot Byte<br>(ENVR Address 0FFFH)              | OVERLAY<br>(SFCS[2]) | Description                                                                                                                                                                      |
|------------------------------------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>0FFH</b><br>(Default Value)<br>(BootRom Disabled) | 0                    | No overlay.<br>After reset 8051 starts execution at physical address 0000H.                                                                                                      |
| Non-0FFH<br>(BootRom Enabled)                        | 1                    | Overlay.<br>0F000H to 0FFFFH (top 4KB of 64KB) overlays to<br>0000H to 0FFFH (bottom 4KB of 64KB).<br>After reset 8051 starts execution from BootRom at physical address 0F000H. |

TABLE 4-5: OVERLAY Bit Value After RESET

T4-5.0 1320

# 4.6 LPC Flash Programming Mode

The SST79LF008 flash memory array can be programmed independently by the LPC Host through the LPC bus interface. See Section 7.0 for the detailed description of all LPC Flash commands.

# 4.7 8051 Controlled Security

SST79LF008 provides an 8051 controlled read/write lock protection through a SuperFlash Security Control Register (SFSEC) in Section 4.71.



# 4.7.1 SuperFlash Security Control Register (SFSEC)

| Location |                | 7       | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 5                                                                                                                                                                                                                                                                                                                                                 | 4                                                | 3              | 2                          | 1                | 0                |  |  |  |  |
|----------|----------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|----------------|----------------------------|------------------|------------------|--|--|--|--|
| 7FC7H    | Read/<br>Write | BTLK    | STICKY_<br>LK                                                                                                                                                                                                                                                                                                                                                                                                                                                         | W_LOCK                                                                                                                                                                                                                                                                                                                                            | R_LOCK                                           | W_LOCK_<br>KBC | NO_MAP_<br>KBC             | W_LOCK_<br>BTROM | NO_MAP_<br>BTROM |  |  |  |  |
|          | Reset          | 0       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                 | 0                                                | 0              | 0                          | Х                | 0                |  |  |  |  |
|          | Symbol         |         | Fund                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | tion                                                                                                                                                                                                                                                                                                                                              |                                                  |                |                            |                  |                  |  |  |  |  |
|          | Х              |         | Not d                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | efined                                                                                                                                                                                                                                                                                                                                            |                                                  |                |                            |                  |                  |  |  |  |  |
|          | BTLK           |         | 1: Lo                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 8051 Boot sector lock bit (valid for 8051 IAP and LPC Flash programming modes)<br>1: Lock - 4 KByte sector at physical address 0000H - 0FFFH is write-protected<br>0: No Lock                                                                                                                                                                     |                                                  |                |                            |                  |                  |  |  |  |  |
|          | STICKY_LK      |         | This I<br>reset<br>1: Lo                                                                                                                                                                                                                                                                                                                                                                                                                                              | ENVR sector lock bit (valid for 8051 IAP and LPC Flash programming modes).<br>This bit can be set by 8051 firmware but it is cleared only by the following hardware<br>reset events: Power On reset, Brown out reset, External pin reset, and LPC Reset.<br>1: Lock - ENVR is read-protected and write-protected (read returns 00H)<br>0: No Lock |                                                  |                |                            |                  |                  |  |  |  |  |
|          | W_LOCH         | K       | 1: Lo<br>Block<br>ACO                                                                                                                                                                                                                                                                                                                                                                                                                                                 | BIOS flash write lock bit (valid for LPC Flash programming mode only)<br>1: Lock - BIOS flash memory area is write-protected (BIOS flash area is Block2-<br>Block15 = 7.0 Mbit, or Block1-Block15 = 7.5 Mbit depending on the status of<br>ACON[1] bit. See Section 6.5)<br>0: No Lock                                                            |                                                  |                |                            |                  |                  |  |  |  |  |
|          | R_LOCK         | (       | BIOS flash read lock bit (valid for LPC Flash programming mode only)<br>1: Lock - BIOS flash memory area is read-protected (BIOS flash area is Block2-<br>Block15 = 7.0 Mbit, or Block1-Block15 = 7.5 Mbit depending on the status of<br>ACON[1] bit. See Section 6.5; LPC read access to BIOS area returns 00H).<br>0: No Lock                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                   |                                                  |                |                            |                  |                  |  |  |  |  |
|          | W_LOCł         | K_KBC   | KBC flash write lock bit (valid for 8051 IAP and LPC Flash programming modes).<br>1: Lock - KBC flash memory area is write-protected (KBC flash area is Block0-<br>Block1 = 128 KByte, or Block0 = 64 KByte depending on the status of ACON[1] bit.<br>See Section 6.5)<br>0: No Lock                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                   |                                                  |                |                            |                  |                  |  |  |  |  |
|          | NO_MAF         | P_KBC   | KBC flash mapping control bit<br>1: KBC area is hidden from the LPC host (KBC flash area is Block0-Block1 = 128<br>KByte, or Block0 = 64 KByte depending on the status of ACON[1] bit.<br>See Section 6.5; LPC read access to KBC area returns 00H).<br>0: KBC area is visible to LPC host.                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                   |                                                  |                |                            |                  |                  |  |  |  |  |
|          | W_LOCH         | <_BTROM | Write lock for BootRom area (valid for 8051 IAP and LPC programming modes).<br>1: Lock - BootRom area at physical address 0F000H - 0FFFFH is write-protected<br>0: No Lock<br>The reset value of this bit is determined as follows.<br>After Power On Reset, External pin reset, Watchdog timer reset, Brown out reset<br>W_LOCK_BTROM = 0 if the ENVR location at address 0FFFH contains 0FFH<br>W_LOCK_BTROM = 1 if the ENVR location at address 0FFFH contains any |                                                                                                                                                                                                                                                                                                                                                   |                                                  |                |                            |                  |                  |  |  |  |  |
|          | NO_MAF         | P_BTROM | Bootl<br>1: Bo<br>host (                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                   | g control bit.<br>at physical ac<br>cess to Boot | Rom area re    | 0H - 0FFFFH<br>turns 00H). | is hidden fro    | m the LPC        |  |  |  |  |

54

There are two sets of lock and mapping control bits that provide read, and write (program/erase) protection on a per-block basis. The first set is controlled by 8051 core. which can protect the BIOS memory space through the W LOCK and R LOCK bits, and KBC firmware space W LOCK KBC, NO MAP KBC, through BTLK, W LOCK BTROM, and NO MAP BTROM bits. The second set is controlled by the LPC host, which can set read or write protections of the flash blocks through block locking registers T MINUS18 LK, ..., T BLOCK LK described in Section 7.0. The LPC host also controls mapping of KBC firmware area via Bit 4 of Mailbox register 94 described in Section 21.0.

Only the protection status set by the 8051 core applies to 8051 firmware initiated Read or Write operations. For LPC host initiated Read or Write operations, both sets of the protection and mapping attributes take effect and the more restrictive one applies.

All of the above locks do not apply to aLPC programming mode.

# 4.8 aLPC MODE

# 4.8.1 Alternate LPC (aLPC) Interface

Besides the standard LPC bus, the SST79LF008 implements an alternate LPC (aLPC) bus to support remote insystem-programming of the on-chip Flash.

Either the LPC bus or the aLPC bus may be connected to the internal LPC bus interface unit (BIU) as shown on Figure 4-7.

A 3-wire input hardware snooper circuit is used to switch the 3 aLPC signals (aLFRAME#, aLCLK and aLAD) from

their default GPI mode to aLPC bus mode, upon detecting unique non-random pattern stream of the а "Enable and Poll" sequence described in Table 4-6.

|                            | 1st Bus<br>Write Cycle <sup>1</sup> |      | 2nd Bus<br>Write Cycle <sup>1</sup> |      | 3rd<br>Write |      | 4th Bus<br>Write Cycle <sup>1</sup> |      |
|----------------------------|-------------------------------------|------|-------------------------------------|------|--------------|------|-------------------------------------|------|
| Command Sequence           | Addr                                | Data | Addr                                | Data | Addr         | Data | Addr                                | Data |
| aLPC Mode Enable_and_Poll  | 55H                                 | AAH  | AAH                                 | 55H  | 55H          | B7H  | AAH                                 | AFH  |
| aLPC Mode Switch_and_Reset | 55H                                 | AAH  | AAH                                 | 55H  | 55H          | B7H  | AAH                                 | 52H  |
| aLPC Mode Exit             | 55H                                 | C5H  | AAH                                 | B6H  |              |      |                                     |      |

TABLE 4-6: aLPC Snooper Command Sequences

1. Each Write Cycle is an aLPC I/O Write Cycle (See Section 4.8.6)

There are 3 states of the aLPC Snooper: IDLE, READY and SWITCHED to aLPC mode. After Power-on, Brownout, External pin, and WDT resets, the SST79LF008 Snooper will start from IDLE state.

In IDLE state LPC bus is connected to the internal LPC interface unit, and hardware only snoops for Enable and Poll aLPC sequence, no other sequence will get the Snooper out of IDLE state. After successfully

receiving a full Enable and Poll command, an interrupt is sent to the 8051 and the hardware Snooper will go to **READY** state.

In READY state, the hardware snoops for all command sequences:

If the hardware snoops an aLPC Exit and Reset • sequence, it will go to IDLE state.



T4-6.0 1320



- If the hardware snoops an Enable\_and\_Poll sequence, it will stay in READY state and return the status of RDY4ALPC bit on aLFRAME# line during SYNC phase of the fourth write cycle of the Enable\_and\_Poll sequence. (If the RDY4ALPC bit in the ALPCBC register is set, the Snooper will drive aLFRAME# low during SYNC phase, otherwise the Snooper will not drive aLFRAME# at all.) No interrupt to the 8051 is generated by the Snooper in the READY state.
- If hardware snoops a Switch\_and\_Reset sequence, it will proceed to SWITCHED state, which enable aLPC flash programming mode.

The aLPC Host can issue Switch\_and\_Reset sequence immediately after Enable\_and\_Poll to force the aLPC mode entry, or it can poll RDY4ALPC bit to make sure that 8051 is ready to switch. The former scenario is recommended when programming a blank chip, or if 8051 firmware is corrupted; the latter scenario provides handshaking with 8051 firmware for graceful entry to the aLPC mode.

In SWITCHED state (aLPC mode) 8051 is permanently kept in rest condition and aLPC bus is connected to internal LPC interface unit. Hardware only snoops for aLPC Exit\_and\_Reset sequence, which returns Snooper back to IDLE state. In SWITCHED state aLPC flash commands described in Section 4.8.6 are used to access the entire SST79LF008 flash memory.

All aLPC Snooper command sequences utilize aLPC I/O Write cycles described in Section 4.8.5. The following figure illustrates the relationship between three states of the aLPC snooper.



FIGURE 4-8: aLPC Snooper State Machine

| Location |                | 7        | 6                            | 5                                                                                                                                                                                                                                                                                                     | 4 | 3 | 2 | 1 | 0 |  |  |  |
|----------|----------------|----------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|--|--|--|
| 7F8BH    | Read/<br>Write | RDY4ALPC | -                            | -                                                                                                                                                                                                                                                                                                     | - | - | - | - | - |  |  |  |
|          | Reset          | 0        | Х                            | Х                                                                                                                                                                                                                                                                                                     | Х | Х | Х | Х | Х |  |  |  |
| Symbol   |                |          | Funct                        | Function                                                                                                                                                                                                                                                                                              |   |   |   |   |   |  |  |  |
|          | -              |          | Not in                       | Not implemented                                                                                                                                                                                                                                                                                       |   |   |   |   |   |  |  |  |
|          | Х              |          | Not de                       | Not defined                                                                                                                                                                                                                                                                                           |   |   |   |   |   |  |  |  |
|          | RDY4AL         | PC       | state 8<br>this bi<br>1: 805 | <ul> <li>8051 is ready for entering aLPC mode. While the Snooper is in IDLE or READY state 8051 can write to this bit. On entry into the SWITCHED state (aLPC mode) this bit is cleared by hardware.</li> <li>1: 8051 is ready for aLPC mode.</li> <li>0: 8051 is not ready for aLPC mode.</li> </ul> |   |   |   |   |   |  |  |  |

# aLPC Bus Control Register (ALPCBC)



# 4.8.2 aLPC Access to BIOS and KBC Code

After entering SWITCHED state a downloader or hardware dongle which functions as an aLPC Host has access to the entire SST79LF008 Flash Memory including ENVR and UNVR. Both BIOS and KBC code can be programmed via the aLPC interface pins using aLPC Memory Write/Read cycles described in Sections 4.8.4 and 4.8.5, with aLPC flash commands listed in Section 4.8.6. For aLPC pin descriptions, see Table 4-7.

All flash memory protection mechanisms (block locking and mapping control) are disabled in aLPC mode.

| Symbol   | Pin Name         | Туре | Functions                                                                                                                                                                                                         |
|----------|------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| aLCLK    | Clock            | I    | To provide a clock input to the control unit (Host driven always)                                                                                                                                                 |
| aLAD     | Address and Data | I/O  | To provide aLPC bus information such as addresses, commands, and data (Host or device driven depending on the direction of the transfer. <sup>1</sup> )                                                           |
| aLFRAME# | Frame            | I/O  | To indicate the start of an aLPC cycle (external aLPC Host driven),<br>and the Ready or Busy status of the device (SST79LF008 driven <sup>2</sup> ).<br>Also used by the Host to abort an aLPC cycle in progress. |

T4-7.0 1320

1. External pull-up resistor should be connected to the aLAD pin in order to maintain pin state during turn-around cycles.

2. The aLFRAME# signal is driven low to indicate Busy, and tri-stated to indicate Ready status. Hence, the external pull-up resistor should also be connected to the aLFRAME# pin.

### 4.8.3 aLPC Memory Write Operation with Auto-Address Increment and Multi-Byte Programming

The aLPC Mode with Auto-Address Increment (AAI) and Multi-Byte Programming features are provided for highspeed programming through the aLPC Host. The Auto-Address Increment in aLPC mode allows loading for only one address for each group of 1, 2, 4, 16, 128-byte, 4K, 64K, or 1M-byte of data. The Multi-Byte Programming feature supports multi-byte programming within one aLPC cycle.

All aLPC flash commands listed in Section 4.8.6 utilize aLPC Memory Write cycles described in this section. In aLPC mode aLAD is the only Data/Address input available, hence aLPC Memory Write cycles are similar to the standard LPC Firmware Memory Write cycles with the exception of using 4 clocks (instead of 1) to transfer each field as shown in Table 4-8-3. The aLPC interface also provides an extended handshaking mechanism between the aLPC Host and the ST79LF008 device for write cycles using the aLFRAME# pin.

When the aLPC Host starts a write cycle, the Host drives aLFRAME# low until the START field is transferred. Then the Host drives aLFRAME# high for four cycles. After those, the Host floats aLFRAME# and monitors the aLFRAME# signal, which is controlled by the SST79LF008 device in order to output Ready/Busy status. The SST79LF008 device would drive aLFRAME# low when the write-buffer is full or the flash memory is busy. When the SST79LF008 device is ready to receive data from the Host, aLFRAME# is switched to high.

Data in the aLPC Data Field is accepted until the internal buffer is full. At that point the device asserts the aLFRAME# low (busy) at the falling edge of aLCLK for the most significant bit of the last accepted nibble to indicate that the internal buffer is full and cannot accept any more data. The clock aLCLK must not be stopped during the program/erase procedure but any data present on aLAD line will be ignored while aLFRAME# is low. When the device is ready, the aLFRAME# signal is deasserted at the falling edge of aLCLK to indicate to the Host that more data (the next group of bytes/bits) can be accepted by the internal data buffer. At this point the host should generate 4 additional aLCLK clock pulses before sending any more data.

See Figure 4-9 for example of aLPC Memory Write cycle including handshaking operations.



| TABLE | 4-8: aLPC Memory Write Cycle Field Definitions |
|-------|------------------------------------------------|
|-------|------------------------------------------------|

| Clock                                       | Field | Field                   | SST79LF008                    |                                                                                                                                                                                                                                                                         |
|---------------------------------------------|-------|-------------------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Cycle                                       | Name  | Contents                | aLAD                          | Comments                                                                                                                                                                                                                                                                |
| 0-3                                         | START | 0,1,1,1                 | IN <sup>1</sup>               | aLFRAME# must be active (low) for the part to respond. Only the last four clocks of the start field (before aLFRAME# transitioning high) should be recognized. The START field contents indicate aLPC Firmware Memory Write cycle (value = 1110).                       |
|                                             |       | LSb MSb                 |                               | Order of bit transfer for this field: LS Bit first                                                                                                                                                                                                                      |
| 4-7                                         | IDSEL | 0,0,0,0<br>(or 1,0,0,0) | IN <sup>1</sup>               | ID selects SST79LF0008 device to respond. If the IDSEL field matches the device ID, then that particular device will respond to the whole bus cycle. Valid IDs = 0000 or 0001.                                                                                          |
|                                             |       | LSb MSb                 |                               | Order of bit transfer for this field: LS Bit first                                                                                                                                                                                                                      |
| 8-35                                        | ADDR  | 28-bit<br>address       | IN <sup>1</sup>               | These 28 clock cycles make up the 28-bit starting memory address $A_{27}$ - $A_0$ .<br>Order of bit transfer for this field: MS Nibble first, LS Bit first: A24,A25,A26,A27, A20,A21,A22,A23, A16,A17,A18,A19, A12,A13,A14,A15, A8,A9,A10,A11, A4,A5,A6,A7, A0,A1,A2,A3 |
| 36-39                                       | MSIZE | S0,S1,S2,S3             | IN <sup>1</sup>               | Device will execute multi-byte write for N bytes.<br>Valid field values S = 0, 1, 2, 4, 7, 12, 13, 14<br>For the respective N = 1, 2, 4, 16, 128, 4K, 64K, 1M bytes                                                                                                     |
|                                             |       | LSb MSb                 |                               | Order of bit transfer for this field: LS Bit first                                                                                                                                                                                                                      |
| 40-(m-1)<br>m = 40+8*N+<br># of wait cycles | DATA  | D0, D1,<br>,<br>D(8*N)  | IN <sup>1</sup>               | Data field consists of 8*N clock periods, where N is defined by MSIZE field. The host will insert wait cycles and pause the data stream when aLFRAME# goes low until it returns high, signifying that the chip is ready for more data.                                  |
|                                             |       | LSb MSb                 |                               | Order of bit transfer for this field: LS Nibble first, LS Bit first, thus DATA is transmitted starting with the least significant bit of Byte 0, sequentially to the most significant bit of byte (N-1).                                                                |
| (m)-(m+3)                                   | TAR0  | 1,1,1,1                 | IN <sup>1</sup>               | In these 4 clock cycles, the aLPC host has driven the aLAD pin to '1'. This is the first part of the bus turnaround.                                                                                                                                                    |
| (m+4)-(m+7)                                 | TAR1  | 1,1,1,1<br>(float)      | Float                         | The aLPC host floats the bus, and SST79LF008 takes control of the bus after these 4 cycles, completing bus turnaround.                                                                                                                                                  |
| (m+8)-(m+11)                                | RSYNC | 0,0,0,0                 | OUT <sup>2</sup>              | During these 4 clock cycles, the SST79LF008 generates a ready-<br>sync (RSYNC) indicating that it has received data.                                                                                                                                                    |
| (m+12)-(m+15)                               | TAR0  | 1,1,1,1                 | OUT <sup>2</sup>              | In these 4 clock cycles, SST79LF0008 has driven the bus to '1'.<br>This is the first part of the bus turnaround.                                                                                                                                                        |
| (m+16)-(m+19)                               | TAR1  | 1,1,1,1<br>(float)      | Float then<br>IN <sup>1</sup> | SST79LF008 floats the bus, and the aLPC host resumes control of the bus after these 4 cycles, completing bus turnaround.                                                                                                                                                |

SST79LF008 reads field contents on the falling edge of the present clock cycle
 Field contents are valid on the falling edge of the present clock cycle, and on the rising edge of the next clock cycle.

T4-8.0 1320





FIGURE 4-9: aLPC Memory Write Cycle

It is possible for SST79LF008 to signal busy status (drive aLFRAME# low) at the falling edge of the very last data bit (clock cycle m-1 on the diagram). This has no effect on the completion of current transaction, i.e., TAR-RSYNC-TAR sequence (clock cycles from m to m+19) is generated without any wait cycles inserted. However, the next LPC transaction must not be started by the Host until the aLFRAME# is returned to high level plus 4 spare clock cycles.

The aLPC Host can abort the transaction in progress by taking over and driving aLFRAME# low for at least 4 cycles with a START value of 1,1,1,1 (similar to the standard LPC abort mechanism). Because of the aLFRAME# extended functionality the following limitation for abort timing should be observed: the Host must not drive aLFRAME# in order to abort the transaction when aLFRAME# is asserted low by the SST79LF008 device as well as 4 clocks prior and 4 clocks after this event.



# 4.8.4 aLPC Memory Read Operation

In the aLPC mode the SST79LF008 device supports AAI and Multi-Byte Memory Read cycles, which allows to load only one address for reading a group of 1, 2, 4, 16, 128-

bytes, 4K, 64K, or 1M-byte of data. These cycles are similar to the standard LPC Firmware Memory Read cycles with the exception of using 4 clocks (instead of 1) to transfer each field.

| TABLE 4 | 4-9: aLPC Memory Read Cycle Field Definitions |
|---------|-----------------------------------------------|
|---------|-----------------------------------------------|

| Clock<br>Cycle       | Field<br>Name | Field<br>Contents       | SST79LF008<br>aLAD            | Comments                                                                                                                                                                                                                                                                |
|----------------------|---------------|-------------------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-3                  | START         | 1,0,1,1                 | IN <sup>1</sup>               | aLFRAME# must be active (low) for the part to respond. Only the last four clocks of the start field (before aLFRAME# transitioning high) should be recognized. The START field contents indicate aLPC Firmware Memory Write cycle (value = 1101).                       |
|                      |               | LSb MSb                 |                               | Order of bit transfer for this field: LS Bit first                                                                                                                                                                                                                      |
| 4-7                  | IDSEL         | 0,0,0,0<br>(or 1,0,0,0) | IN <sup>1</sup>               | ID selects SST79LF0008 device to respond. If the IDSEL field matches the device ID, then that particular device will respond to the whole bus cycle. Valid IDs = 0000 or 0001.                                                                                          |
|                      |               | LSb MSb                 |                               | Order of bit transfer for this field: LS Bit first                                                                                                                                                                                                                      |
| 8-35                 | ADDR          | 28-bit<br>address       | IN <sup>1</sup>               | These 28 clock cycles make up the 28-bit starting memory address $A_{27}$ - $A_0$ .<br>Order of bit transfer for this field: MS Nibble first, LS Bit first: A24,A25,A26,A27, A20,A21,A22,A23, A16,A17,A18,A19, A12,A13,A14,A15, A8,A9,A10,A11, A4,A5,A6,A7, A0,A1,A2,A3 |
| 36-39                | MSIZE         | S0,S1,S2,S3             | IN <sup>1</sup>               | Device will execute multi-byte write for N bytes.<br>Valid field values S = 0, 1, 2, 4, 7<br>For the respective N = 1, 2, 4, 16 Bytes                                                                                                                                   |
|                      |               | LSb MSb                 |                               | Order of bit transfer for this field: LS Bit first                                                                                                                                                                                                                      |
| 40-43                | TAR0          | 1,1,1,1                 | IN <sup>1</sup>               | In these 4 clock cycles, the aLPC host has driven the aLAD pin to '1'. This is the first part of the bus turnaround.                                                                                                                                                    |
| 44-47                | TAR1          | 1,1,1,1<br>(float)      | Float                         | The aLPC host floats the bus, and SST79LF008 takes control of the bus after these 4 cycles, completing bus turnaround.                                                                                                                                                  |
| 48-51                | SYNC          | 0,1,1,0                 | OUT <sup>2</sup>              | During these 4 clock cycles, the SST79LF008 generates a long-wait-<br>sync (LWSYNC) indicating that data is not ready, yet.                                                                                                                                             |
| 52-(n-5)             |               |                         | OUT <sup>2</sup>              | SST79LF008 continues to generate long-wait-sync.                                                                                                                                                                                                                        |
| (n-4)-(n-1)          |               | 0,0,0,0                 | OUT <sup>2</sup>              | During these 4 clock cycles, SST79LF008 generates a ready-sync (RSYNC) indicating that the least-significant bit of the least significant data byte will be sent on the next clock cycle.                                                                               |
| n-(m-1)<br>m = n+8*N | DATA          | D0, D1,<br>,<br>D(8*N)  | OUT <sup>2</sup>              | Data field consists of 8*N clock periods, where N is defined by MSIZE field. The host will insert wait cycles and pause the data stream when aLFRAME# goes low until it returns high, signifying that the chip is ready for more data.                                  |
|                      |               | LSb MSb                 |                               | Order of bit transfer for this field: LS Nibble first, LS Bit first, thus DATA is transmitted starting with the least significant bit of Byte 0, sequentially to the most significant bit of Byte(N-1).                                                                 |
| (m)-(m+3)            | TAR0          | 1,1,1,1                 | OUT <sup>2</sup>              | In these 4 clock cycles, SST79LF0008 has driven the bus to '1' This is the first part of the bus turnaround.                                                                                                                                                            |
| (m+4)-(m+7)          | TAR1          | 1,1,1,1<br>(float)      | Float then<br>IN <sup>1</sup> | The aLPC host floats the bus, and the aLPC host resumes control of the bus after these 4 cycles, completing bus turnaround.                                                                                                                                             |

1. SST79LF008 reads field contents on the falling edge of the present clock cycle

2. Field contents are valid on the falling edge of the present clock cycle, and on the rising edge of the next clock cycle.

T4-9.0 1320





FIGURE 4-10: aLPC Memory Read Cycle



# 4.8.5 aLPC I/O Write Operation

When the SST79LF008 device is switched into aLPC mode it supports aLPC I/O Write and Read cycles in addition to the aLPC Memory Write and Read cycles previously described. However, in aLPC mode all LPC logical I/O devices are disabled (as all Configuration registers are reset - see Section 23.2). Therefore the only useful

aLPC I/O operations are aLPC Write cycles utilized by the aLPC Host to issue aLPC Snooper commands described in Table 4-6. These cycles are similar to the standard LPC I/O Write cycles except 4 clocks (instead of 1) are used to transfer each field. The following exceptions with regards to

aLAD and aLFRAME# control are also applied to the aLPC I/O cycles when the Snooper is in IDLE and READY states:

- In IDLE and READY states the Snooper tri-states the aLAD line and does not return RSYNC to the Host
- In READY state the Snooper returns the status of RDY4ALPC bit on aLFRAME# during SYNC phase of the fourth write cycle of the Enable\_and\_Poll sequence.

Examples of I/O Write cycles before and after entry to SWITCHED state (aLPC mode) are shown in Figures 4-11 and 4-12, respectively.

TABLE 4-10: aLPC I/O Write Cycle Field Definitions

| Clock<br>Cycle | Field<br>Name | Field<br>Contents  | SST79LF008<br>aLAD            | Comments                                                                                                                                                                                                                                                     |
|----------------|---------------|--------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-3            | START         | 0,0,0,0            | IN <sup>1</sup>               | aLFRAME# must be active (low) for the part to respond. Only the last<br>four clocks of the start field (before aLFRAME# transitioning high)<br>should be recognized. The START field contents indicate aLPC Firm-<br>ware Memory Write cycle (value = 0000). |
|                |               | LSb MSb            |                               | Order of bit transfer for this field: LS Bit first                                                                                                                                                                                                           |
| 4-7            | CYC_TYPE      | 0,1,0,0            | IN <sup>1</sup>               | Cycle type field indicates aLPC I/O Write cycle (value - 0010)                                                                                                                                                                                               |
|                |               | LSb MSb            |                               | Order of bit transfer for this field: LS Bit first                                                                                                                                                                                                           |
| 8-23           | ADDR          | 16-bit<br>address  | IN <sup>1</sup>               | These 16 clock cycles make up the 16-bit I/O address A <sub>15</sub> -A <sub>0</sub> .<br>Order of bit transfer for this field: MS Nibble first, LS Bit first:<br>A12,A13,A14,A15, A8,A9,A10,A11, A4,A5,A6,A7, A0,A1,A2,A3                                   |
| 24-31          | DATA          | D0,D1,D7           | IN <sup>1</sup>               | These 8 clock cycles are used to transmit one Data byte.                                                                                                                                                                                                     |
|                |               | LSb MSb            |                               | Order of bit transfer for this field: LS Bit first                                                                                                                                                                                                           |
| 32-35          | TAR0          | 1,1,1,1            | IN <sup>1</sup>               | In these 4 clock cycles, the aLPC host has driven the aLAD pin to '1'. This is the first part of the bus turnaround.                                                                                                                                         |
| 36-39          | TAR1          | 1,1,1,1<br>(float) | Float                         | The aLPC host floats the bus, and SST79LF008 takes control of the bus after these 4 cycles, completing bus turnaround.                                                                                                                                       |
| 40-43          | SYNC          | 0,0,0,0            | OUT <sup>2,3</sup>            | During these 4 clock cycles, the SST79LF008 generates a ready-<br>sync (RSYNC) indicating that data is not ready, yet.                                                                                                                                       |
| 44-47          | TAR0          | 1,1,1,1            | OUT <sup>2,3</sup>            | In these 4 clock cycles, the aLPC host has driven the bus pin to '1'.<br>This is the first part of the bus turnaround.                                                                                                                                       |
| 48-51          | TAR1          | 1,1,1,1<br>(float) | Float then<br>IN <sup>1</sup> | SST79LF008 floats the bus, and the aLPC host resumes control of the bus after these 4 cycles, completing bus turnaround.                                                                                                                                     |

1. SST79LF008 reads field contents on the falling edge of the present clock cycle

T4-10.0 1320

Field contents are valid on the falling edge of the present clock cycle, and on the rising edge of the next clock cycle.

3. When the Snooper is in IDLE or READY state, aLAD is always floated in SST79LF008 (and SYNC = 1,1,1,1).





FIGURE 4-11: aLPC I/O Write Cycle (IDLE or READY state)





FIGURE 4-12: aLPC I/O Write cycle (SWITCHED state)



# 4.8.6 aLPC Flash Commands

When aLPC Mode is enabled (i.e., the aLPC Snooper is in SWITCHED state) all aLPC Memory Write operations are interpreted by the flash command interface. Commands consist of one or more sequential bus write cycles described in Section 4.8.4. The aLPC flash commands are summarized in Table 4-11. For a detailed description of each command, refer to Section 7.3, as aLPC and standard LPC flash command are functionally similar.

| TABLE | 4-11: aLPC Bus Flash Command Definitions |
|-------|------------------------------------------|
|       |                                          |

|                                     | Bus Cycles |       | First Bus | s Cycle    | Seco  | ond Bus C | ycle |
|-------------------------------------|------------|-------|-----------|------------|-------|-----------|------|
| Command                             | Required   | Oper  | Addr      | Data       | Oper  | Addr      | Data |
| Read-Array/Reset                    | 1          | Write | Х         | FFH        |       |           |      |
| Read-Device-ID<br>Read Unique ID    | ≥2         | Write | Х         | 90H        | Read  | IA        | ID   |
| Read-Status-Register                | 2          | Write | Х         | 70H        | Read  | Х         | SRD  |
| Clear-Status-Register               | 1          | Write | Х         | 50H        |       |           |      |
| Sector-Erase                        | 2          | Write | Х         | 30H        | Write | SA        | D0H  |
| Block-Erase                         | 2          | Write | Х         | 20H        | Write | BA        | D0H  |
| Program                             | 2          | Write | Х         | 40H or 10H | Write | WA        | WD   |
| Erase-Suspend                       | 1          | Write | Х         | B0H        |       |           |      |
| Erase-Resume                        | 1          | Write | Х         | D0H        |       |           |      |
| User-Unique-ID Program              | 2          | Write | Х         | A5H        | Write | WA        | WD   |
| User-Unique-ID<br>Program-Lockout   | 2          | Write | Х         | 85H        | Write | X         | 00H  |
| Enter UNVR (3K OTP) /<br>Enter ENVR | 2          | Write | X         | 60H        | Write | X         | 76H  |

T4-11.0 1320



# 5.0 POWER, RESET AND CLOCK SOURCES

# 5.1 Power Planes

SST79LF008 has two power planes:  $V_{DD}$  and  $AV_{DD}$ . The digital logic and on-chip memory are powered by  $V_{DD}$ ; the analog circuits in ADC and DAC are powered by  $AV_{DD}$ . Both power planes must be applied/removed simultaneously.

SST recommends a high frequency 0.1  $\mu F$  ceramic capacitor to be placed as close as possible between each  $V_{DD}$  and  $V_{SS}$  pin, less than 1cm away from  $V_{DD}$  pin. Additionally, a low frequency tantalum capacitor (4.7  $\mu f$  min.) from  $V_{DD}$  to  $V_{SS}$  should be placed on the common power/ground net as close as possible to the chip.

SST recommends a high frequency 0.1  $\mu F$  ceramic capacitor to be placed as close as possible between each AV\_{DD} and AV\_{SS} pin, less than 1cm away from AV\_{DD} pin. Additionally, a low frequency tantalum capacitor (4.7  $\mu f$  min.) from AV\_{DD} to AV\_{SS} should be placed on the common analog power/ground net as close as possible to the chip.

Note also that a high frequency 1  $\mu F$  ceramic capacitor must be placed as close as possible between SST79LF008 internal regulator output VREG and V<sub>SS</sub> pin, less than 1 cm away from V<sub>REG</sub> pin.

For correct SST79LF008 operation all power pins must be connected to the respective power/ground planes, see Section 2.1, "Pin Descriptions".

# 5.2 Reset Sources

SST79LF008 has the following reset sources:

- 1. Power-On reset (POR)
- 2. External Chip reset (RESET# pin)
- 3. Brown-out detection reset (BOR)
- 4. Watchdog timer (WDT) reset
- 5. aLPC Soft reset
- 6. LPC Soft reset
- 7. 8051 Soft reset
- 8. Configuration Soft reset
- 9. LPC Interface reset (LRESET# pin)



#### TABLE5-1: SST79LF008 Reset Sources

| Reset<br>Source                 | Reset Mechanism                                                                                                                                              | Reset Modules                                                                            | Restart<br>8051 code<br>after reset | Maskable | ldle<br>Wake<br>up | PD<br>Wake<br>up |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-------------------------------------|----------|--------------------|------------------|
| POR                             | V <sub>DD</sub> is powered up                                                                                                                                | The SST79LF008 chip                                                                      | Yes <sup>1</sup>                    | No       | Yes                | Yes              |
| External<br>Reset               | RESET# pin is asserted low                                                                                                                                   | The SST79LF008 chip                                                                      | Yes <sup>1</sup>                    | No       | Yes                | Yes              |
| BOR                             | VDD is below Brown-Out threshold                                                                                                                             | The SST79LF008 chip                                                                      | Yes <sup>1</sup>                    | Yes      | Yes                | No               |
| WDT reset                       | Watchdog timer underflow                                                                                                                                     | The SST79LF008 chip                                                                      | Yes <sup>1</sup>                    | Yes      | Yes                | Yes              |
| aLPC<br>Soft Reset              | <ul><li>(a) Entry to aLPC mode via aLPC</li><li>Switch_and_Reset sequence</li><li>(b) Exit from aLPC mode via aLPC</li><li>Exit_and_Reset sequence</li></ul> | The SST79LF008 chip, except the aLPC snooper                                             | Yes <sup>1</sup>                    | No       | Yes                | Yes              |
| LPC<br>Soft Reset               | Force LPC Soft Reset command received via LPC bus                                                                                                            | 8051 MCU, selected MMCRs,<br>and Configuration registers;<br>clear SFSC[2] (OVERLAY) bit | Yes <sup>2</sup>                    | Yes      | Yes                | Yes              |
| 8051<br>Soft Reset              | Transition of SOFTRST = SFCS[3]<br>bit from '0' to '1'                                                                                                       | 8051 MCU and<br>selected MMCRs;<br>clear SFSC[2] (OVERLAY) bit                           | Yes <sup>2</sup>                    | No       | N/A                | N/A              |
| Configuration<br>Soft Reset     | Transition of Bit 0 in Chip Control register 0 from '0' to '1'                                                                                               | Configuration registers                                                                  | No                                  | No       | N/A                | N/A              |
| External LPC<br>Interface reset | LRESET# pin is asserted low                                                                                                                                  | The LPC bus interface and flash block locking registers                                  | No                                  | No       | Yes                | Yes              |

T5-1.0 1320

1. Start address and OVERLAY bit state is determined by ENVR contents as described in Section4.4.5.

2. Start address is 0000H regardless of ENVR contents and OVERLAY bit is always cleared.

The SST79LF008 reset block diagram is shown on Figure 5-1. POR, External Reset, BOR, and WDT resets are internally "or-ed" to form an internal reset signal to the whole SST79LF008 chip. This signal is asserted as soon as any of the above reset sources is asserted and will be deasserted only when none of them is asserted. The 16-bit reset extender counter guarantees that the chip will be held in reset state for at least 65,536 clocks of RCLK after all these reset sources are de-asserted. The extended reset signal applied to aLPC Snooper and "or-ed" with aLPC Soft reset to form a flash memory reset. The 7-bit configuration extender counter keeps 8051 MCU and other peripheral modules in reset state for 128 clocks of RCLK, while the internal configuration is performed in hardware. After the configuration extender is expired and the internal Chip Logic Reset signal is de-asserted, all SFRs (see Section 3.4), MMCRs (see Section 3.5), flash block locking registers (see Section 7.6), and configuration registers (see Section 23.2) contain their respective reset values. The 8051 program execution will restart from either address 0000H or F000H (BootRom) depending on the ENVR contents as described in Section 4.5.

The 8051 firmware Soft Reset affects the 8051 MCU core including all SFRs, and selected MMCRs as specified in Section 3.5. After the 8051 Soft reset the OVERLAY bit is always cleared. Thus, the 8051 program execution will restart from address 0000H.

The LPC Soft reset affects the 8051 MCU core including all SFRs, selected MMCRs as specified in Section 3.5, and all Configuration registers. After the LPC Soft reset the OVER-LAY bit is always cleared. Thus, the 8051 program execution will restart from address 0000H.

The Configuration Soft reset affects configuration registers only; it does not restart 8051 code execution.

The LPC Interface reset signal initializes LPC interface state machine (including Serialized IRQ, and CLKRUN# mechanisms), and resets flash memory command sequence described in Section 7.3 as well as all flash block locking registers described in Section 7.6. The LPC reset does not restart 8051 code execution.

**Note**. The internal SRAM is not affected by any type of reset. On power up, the SRAM content is indeterminate.



Advance Information



FIGURE 5-1: Reset Block Diagram

# 5.2.1 Power-On Reset

The SST79LF008 provides an internal power-on reset circuit, which generates Power-On Reset when  $V_{DD}$  power is applied. The POR is extended internally until ring oscillator clock is stabilized and counted at least 65,536 times. See Figure 5-1. However, the 32.768 KHz oscillator has much larger power on stabilization time. Therefore, accuracy of any module in the XCLK domain (see Table 5-3) is not guaranteed immediately after POR. If necessary the external RC circuitry can be used to additionally extend POR, see Figure 5-2, or 8051 firmware can implement software delay before using XCLK controlled devices.

The POF flag in PCON register is set to indicate that Power-On Reset has occurred, see Section 11.4.



FIGURE 5-2: External Reset Circuit



### 5.2.2 External Reset

An External reset, derived from the external circuitry connected to the RESET# pin of SST79LF008, will reset the entire chip. In order to properly reset the device, a logic level low must be applied to the RESET# pin for at least 48 cycles of 8051 core clock (CCLK) once V<sub>DD</sub> power is already applied. External reset can not be masked. If External reset occurs when the chip is in Idle or Power Down mode, it will cause the chip to exit the respective mode.

#### 5.2.3 Brown-out Detection Reset

The device includes a Brown-Out detection circuit to protect the system from severe supply voltage  $V_{DD}$  fluctuations. When  $V_{DD}$  drops below the brown-out voltage

threshold, the detector circuit generates a brown-out reset to reset the whole device. The BOR is de-asserted automatically after VDD exceeds the brown-out voltage threshold. Brown-out reset can be masked via BOREN bit in RSTCON register (by default BOR is enabled). If BOR occurs when the chip is in Idle mode, it will cause the chip to exit the respective mode. BOR is not generated when chip is in Power Down mode.

The BOF flag in PCON register () is set when brown-out condition is detected, provided BOR is enabled. See Section 11.4.

#### 5.2.3.1 Reset Control Register (RSTCON)

| Location |        | 7     | 6                                                 | 5                                                  | 4           | 3             | 2                | 1       | 0     |  |  |
|----------|--------|-------|---------------------------------------------------|----------------------------------------------------|-------------|---------------|------------------|---------|-------|--|--|
|          | Read   | -     | -                                                 | -                                                  | -           | -             | WDTPOL           | WDTRSTE | BOREN |  |  |
| 7F2EH    | Write  |       |                                                   |                                                    |             |               |                  | N       |       |  |  |
|          | Reset  | Х     | Х                                                 | Х                                                  | Х           | Х             | 0                | 0       | 1     |  |  |
|          | Symbol |       | Functi                                            | on                                                 |             |               |                  |         |       |  |  |
| -        |        |       | Not im                                            | Not implemented                                    |             |               |                  |         |       |  |  |
| х        |        |       | Not de                                            | Not defined                                        |             |               |                  |         |       |  |  |
| WDTPOL   |        |       | WDT C                                             | WDT Output Polarity control bit                    |             |               |                  |         |       |  |  |
|          |        |       | 1: WD                                             | 1: WDT output is High Active (when WDT underflows) |             |               |                  |         |       |  |  |
|          |        |       | 0: WDT output is Low Active (when WDT underflows) |                                                    |             |               |                  |         |       |  |  |
| WDTRSTEN |        |       | WDT F                                             | Reset Enable                                       | e bit       |               |                  |         |       |  |  |
|          |        |       |                                                   | ble WDT Re                                         |             |               |                  |         |       |  |  |
|          |        |       | 0: Disa                                           | 0: Disable WDT Reset                               |             |               |                  |         |       |  |  |
| BOREN    |        | BOR E | BOR Enable bit                                    |                                                    |             |               |                  |         |       |  |  |
|          |        | •     |                                                   | own mode, l                                        | BOR is disa | bled regardle | ss of this bit s | state.) |       |  |  |
|          |        |       |                                                   | ble BOR                                            |             |               |                  |         |       |  |  |
|          |        |       | 0: Disa                                           | ble BOR                                            |             |               |                  |         |       |  |  |

#### 5.2.4 Watchdog Timer (WDT) Reset

Watchdog Timer (WDT) reset is generated when WDT underflows (i.e., when firmware failed to reload WDT within the programmed watchdog interval). WDT reset affects the entire device. It can be masked by WDTRSTEN bit in RST-CON register (by default WDT reset is disabled). In addition WDT controls allow firmware to stop WDT completely, or only in Power Down mode. For more WDT operation details, see Section 10.0.

### 5.2.5 aLPC Soft Reset

A Switch\_and\_Reset sequence, sent over an aLPC bus, resets the whole chip with the exception of aLPC Snooper. Then the SST79LF008 device will enter aLPC mode with flash memory bus owned by the aLPC Host and 8051

MCU held in reset, until aLPC exit sequence terminates aLPC mode. After Exit\_and\_Reset sequence is received the SST79LF008 chip is reset again. The reset extender does not affect aLPC Soft reset duration. The aLPC Host is required to provide at least 8 spare aLPC clock cycles after the end Switch\_and\_Reset or Exit\_and\_Reset sequence. For the aLPC sequences details, see Section 4.8. The aLPC Soft reset can not be masked. If it occurs when the chip is in Idle or Power Down mode, the respective mode is terminated.



# 5.2.6 LPC Soft Reset

A Force LPC Soft Reset command sent over LPC bus will reset the 8051 MCU core, including all SFRs, selected MMCRs and all Configuration registers. After this command flash memory bus is owned by the LPC Host, and 8051 is held in reset state, until a Release LPC Soft Reset command is received. The reset extender and configuration extender counters do not affect LPC Soft reset. See Section 7.3.10 for command details and Section 3.5 for the list of affected MMCRs. The LPC Soft reset can be masked via LRSTCOREENB bit in LPC bus monitor register described in Section 23.1. If LPC Soft reset occurs when the chip is in Idle or Power Down mode, the respective mode is terminated.

# 5.2.7 8051 Firmware Soft Reset

A transition from 0 to 1 of SFCS[3] (SOFTRST) bit will generate an internal reset signal, which resets the 8051 MCU core and selected MMCRs. The reset extender and configuration extender counters do not affect 8051 Soft reset. See Section 3.5 for the list of affected MMCRs.

### 5.2.8 Configuration Soft Reset

When bit 0 of the chip control register 0 transitions from 0 to 1, only the configuration registers are reset. For more details, see Section 23.2.

#### 5.2.9 LPC Interface Reset

LPC Interface reset is controlled by the LRESET# input. When the LRESET# signal is active low, the SST79LF008 device ignores the LFRAME# and LCLK inputs, and tristates the address/data signals of LPC bus LAD[3:0], as well as SERIRQ and CLKRUN# outputs. The LRESET# resets LPC interface state machine (including SERIRQ and CLKRUN# mechanisms), flash command sequencer and flash block locking registers described in Section 7.6. During this process, the STICKY\_LK bit in SFSEC register is also cleared. The reset extender and configuration extender counters do not affect LPC Interface reset. The LRESET# can not be masked, and it generates an interrupt to 8051, which can be configured as a wake up event from Idle or Power Down mode.

If LRESET# signal is activated while flash memory Erase is in progress, the SRI hardware automatically suspends Erase operation and switches flash memory to read array mode during the LPC Host read access after LRESET# is de-asserted. LPC read operation within any flash sector/ block, other than the suspended one, would complete normally in this case. The erase operation will automatically resume on completion of the LPC Host read. If LPC reset occurs when flash bus was turned over to the LPC Host (using mechanism (a) or (b) described in Section 4.3), it is LPC Host software and 8051 firmware's responsibility to restore 8051 flash bus ownership after LRESET# is deasserted and erase operation is finished.

If LRESET# signal is activated after Force LPC Soft Reset command, the flash bus will be automatically released to 8051, and 8051 will restart code execution when LRESET# is de-asserted. In a case when erase operation was initiated during LPC Soft Reset, and aborted by LRESET# assertion (i.e., mechanism (c) in Section 4.3 was used), the 8051 will not be able to properly fetch flash memory contents, making code execution results unpredictable. Therefore mechanism (c), is not recommended for flash update unless flash memory is blank or corrupted.

The LRESET# signal has no effect in aLPC mode.



# 5.3 Clock Sources

### 5.3.1 Clock Input Options

The SST79LF008 has several clock sources which are listed in Table 5-2.

#### TABLE5-2: SST79LF008 Clock Sources

| Clock Source                                                         | Frequency    | Destination                                                                |
|----------------------------------------------------------------------|--------------|----------------------------------------------------------------------------|
| Internal Ring Oscillator Clock (RCLK)                                | 10-20MHz     | 8051 CPU and core peripherals                                              |
| External Clock (ECLK) signal                                         | 4-16MHz      | PLL, 8051 CPU and core peripherals                                         |
| Internal PLL-Generated Clock (PCLK),<br>derived from ECLK            | Up to 33 MHz | 8051 CPU and core peripherals                                              |
| External crystal connected to the internal oscillator circuit (XCLK) | 32.768KHz    | Hibernation timer, Timer0, Timer1, Watchdog timer, Fan tachometer, and PWM |
| External LPC Clock (LCLK)                                            | Up to 33MHz  | LPC Bus Interface                                                          |
| External aLPC Clock (aLCLK)                                          | Up to 5MHz   | aLPC Bus Interface                                                         |

T5-2.0 1245

Internal clock sources include Ring Oscillator and PLL, which, however, depends on external clock ECLK. External clock sources include ECLK as well as LPC clocks LCLK and aLCLK. The 32.768 kHz clock is generated by the circuitry which combines an on-chip oscillator and an external crystal as shown on Figure 5-3.

### 5.3.1.1 Crystal Oscillator



FIGURE 5-3: Crystal Oscillator Circuit

| TABLE | 5-3: Crystal Oscillator Circuit Components |
|-------|--------------------------------------------|
|-------|--------------------------------------------|

| RF   | Rs      | C1,C2   | Crystal Frequency |
|------|---------|---------|-------------------|
| 10MΩ | 0 200ΚΩ | 10 35pF | 32.768KHz         |

T5-3.0 1245



# 5.3.2 Clock Selection Control and Clock Domains

The 8051 CPU and core peripherals clock (CCLK) are derived from three different clock sources—the on-chip ring oscillator (RCLK), the PLL clock (PCLK), and the external clock source (ECLK). The 8051 can be programmed to switch the clock source during normal code execution. The 8051 clock source can be selected through the Clock

Source Control Register (CLKSRCCON). In addition peripheral modules Time0, Timer1, and PWM have their own clock selection control registers described in Section 10.0. The 8051 core clock, as well as some peripheral clocks, are stopped when 8051 enters either Idle mode or Power Down mode. for PCON register description, see Section 11.4.



The SST79LF008 clock usage and clock domains are summarized in the Table 5-4.

|  | TABLE | 5-4: Clock Domains for SST79LF008 Modules |
|--|-------|-------------------------------------------|
|--|-------|-------------------------------------------|

| MODULE            | Clock Domain             | Clock status in Idle mode | Clock status in Power Down                |
|-------------------|--------------------------|---------------------------|-------------------------------------------|
| 8051              | 8051 CPU clock           | stop                      | stop                                      |
| Timer 0/1         | 8051 core clock          | run                       | stop                                      |
|                   | Peripheral clock         | run                       | stop                                      |
| Timer 2           | 8051 core clock          | run                       | stop                                      |
| Hibernation timer | Crystal Oscillator clock | run                       | run                                       |
| WDT               | Peripheral clock         | run                       | run/stop depends on (WDTCSR[7])           |
| Fan Tachometer    | Peripheral clock         | run                       | run/stop depends on<br>(FANTIMEBASE[7:6]) |
| PWM               | 8051 core clock          | run                       | stop                                      |
|                   | Crystal Oscillator clock | run                       | run                                       |
| ADC               | 8051 core clock          | run                       | stop                                      |
| DAC               | 8051 core clock          | run                       | stop                                      |
| PWM LED           | Crystal Oscillator clock | run                       | run                                       |
| UART              | 8051 core clock          | run                       | stop                                      |
| SPI               | 8051 core clock          | run                       | stop                                      |
| SMBus             | 8051 core clock          | run                       | stop                                      |
| PS/2              | 8051 core clock          | run                       | stop                                      |
| GPIO              | 8051 core clock          | run                       | stop (retain I/O state)                   |
| LPC Interface     | LPC clock                | X <sup>1</sup>            | X <sup>1</sup>                            |

1. LPC clock status is controlled by the external LPC Host, it is not affected by 8051 Idle or Power Down mode.



| Location |           | 7   | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 5                                                                                                                                                                                                                                                                                                                                                                                                            | 4                                           | 3     | 2      | 1       | 0      |  |  |  |  |
|----------|-----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-------|--------|---------|--------|--|--|--|--|
|          | Read      | -   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | CLKSEL_                                                                                                                                                                                                                                                                                                                                                                                                      | ROSCEN                                      | PLLOK | XTALEN | PLLSTOP | ECLKOK |  |  |  |  |
| 7F27H    | Write     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 8051                                                                                                                                                                                                                                                                                                                                                                                                         |                                             | -     |        |         | -      |  |  |  |  |
|          | Reset     | Х   | Х                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                            | 1                                           | 0     | 1      | 0       | 0      |  |  |  |  |
|          | Symbol    |     | Functi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | on                                                                                                                                                                                                                                                                                                                                                                                                           |                                             |       |        |         |        |  |  |  |  |
|          | -         |     | Not im                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Not implemented                                                                                                                                                                                                                                                                                                                                                                                              |                                             |       |        |         |        |  |  |  |  |
|          | Х         |     | Not de                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Not defined                                                                                                                                                                                                                                                                                                                                                                                                  |                                             |       |        |         |        |  |  |  |  |
|          | CLKSEL_80 | 051 | 1:805                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 8051 clock source selection bit<br>1: 8051 Clock source CCLK = MCLK (i.e., either PCLK or ECLK)<br>0: 8051 Clock source CCLK = RCLK                                                                                                                                                                                                                                                                          |                                             |       |        |         |        |  |  |  |  |
|          | ROSCEN    |     | The 80<br>Power<br>Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Ring Oscillator Enable bit<br>The 8051 firmware can read/write this bit. It is also reset by hardware on entry to<br>Power Down mode, and set on wake up from Power Down mode<br>Enable Ring oscillator<br>0: Stop Ring oscillator                                                                                                                                                                           |                                             |       |        |         |        |  |  |  |  |
|          | PLLOK     |     | <ul> <li>PLL status bit</li> <li>This bit is set when PLL output signal is stabilized. If firmware attempts to select PCLK as 8051 core clock source when this bit is cleared, hardware uses RCLK instead, until PLLOK is set. Only after PLLOK is set 8051 core clock is switched PCLK. An interrupt is generated when PLLOK bit changes from 0 to 1.</li> <li>1: PLL is stabilized (the PLL stabilization counter reaches 3F00H = 16,128)</li> <li>0: PLL is not stabilized because of any of the following 3 conditions</li> <li>PLL stopped (PLLSTOP =1, PLL stabilization counter is reset)</li> <li>ECLK stopped (ECLKOK = 0, PLL stabilization counter is reset)</li> <li>PLL stabilization time has not expired (PLLSTOP = 0, ECLKOK = 1, PLL stabilization counter is running but has not reached 3F00H, yet). This bit at PLL stabilization counter are cleared in hardware on entry to Power Dowr</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                                              |                                             |       |        |         |        |  |  |  |  |
|          | XTALEN    |     | 1: Enal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | l Oscillator E<br>ble 32.768Kl                                                                                                                                                                                                                                                                                                                                                                               | nable bit<br>Hz crystal os<br>Hz crystal os |       |        |         |        |  |  |  |  |
|          | PLLSTOP   |     | PLL control and MCLK selection bit<br>1: Select MCLK = ECLK (PLL module is stopped, stabilization counter is reset<br>0: Select MCLK = PCLK (PLL module is running)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                              |                                             |       |        |         |        |  |  |  |  |
|          | ECLKOK    |     | This bit<br>core clu<br>ECLKC<br>An inte<br>1: ECL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | External clock ECLK status bit<br>This bit is set when ECLK is applied. If firmware attempts to select ECLK as 8051<br>core clock when this bit is cleared, the hardware uses RCLK instead, until<br>ECLKOK is set. Only after ECLKOK is set to 8051 core clock is switched to ECLK<br>An interrupt is generated when ECLKOK changes from 0 to 1 or from 1 to 0<br>1: ECLK is running<br>0: ECLK has stopped |                                             |       |        |         |        |  |  |  |  |

#### 5.3.2.1 Clock Source Control Register (CLKSRCCON) .



#### 5.3.2.2 PLL M Value Register (PLLM)

| Location |       | 7 | 6 | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|-------|---|---|-------|-------|-------|-------|-------|-------|
|          | Read  | - | - | PLLM5 | PLLM4 | PLLM3 | PLLM2 | PLLM1 | PLLM0 |
| 7F35H    | Write |   |   |       |       |       |       |       |       |
|          | Reset | Х | Х | 1     | 0     | 0     | 0     | 1     | 0     |

#### 5.3.2.3 PLL PS Value Register (PLLPS)

| Location |       | 7 | 6 | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|-------|---|---|-------|-------|-------|-------|-------|-------|
|          | Read  | - | - | PLLP1 | PLLP0 | PLLS3 | PLLS2 | PLLS1 | PLLS0 |
| 7F36H    | Write |   |   |       |       |       |       |       |       |
|          | Reset | Х | Х | 1     | 1     | 0     | 0     | 1     | 0     |

| Symbol                                |  |
|---------------------------------------|--|
| -                                     |  |
| Х                                     |  |
| PLLM[5:0],<br>PLLP[1:0],<br>PLLS[3:0] |  |

Function Not implemented Not defined PLL Output frequency control<sup>\*†</sup>  $F_{PLLO} = F_{PLLI} * m/(p*s)$  m = 2\*(M+2) p = (P+1)s = 2\*(S+2)

| FPLLI (MHz) (ECLK) | Р | М  | S | FPLLO (MHz) (PCLK) |
|--------------------|---|----|---|--------------------|
| 4                  | 0 | 34 | 7 | 16                 |
| 4                  | 0 | 34 | 4 | 24                 |
| 4                  | 0 | 30 | 2 | 32                 |
| 8                  | 1 | 34 | 7 | 16                 |
| 8                  | 1 | 34 | 4 | 24                 |
| 8                  | 1 | 30 | 2 | 32                 |
| 12                 | 2 | 34 | 7 | 16                 |
| 12                 | 2 | 34 | 4 | 24                 |
| 12                 | 2 | 30 | 2 | 32                 |
| 14.318             | 3 | 38 | 7 | 15.9089            |
| 14.318             | 3 | 38 | 4 | 23.8633            |
| 14.318             | 3 | 34 | 2 | 32.2155            |
| 16                 | 3 | 34 | 4 | 24                 |
| 16                 | 3 | 30 | 2 | 32                 |

T5-4.1245

#### 5.3.3 Clock Switching after Power On and Reset

When SST79LF008 is powered on, the default clock source is always the internal ring oscillator. The RCLK continues to be used until all of the following events have taken place.

1. The 65,536 + 128 counts of RCLK are completed

### 2. ECLK is running

- 3. PWRGOOD pin is high
- 4. RCLK is not selected by firmware as the core clock (i.e., CLKSEL\_8051 = 1)
- 5. The PLL output clock (if enabled), has been through 16,128 (3F00H) counts

<sup>\*</sup> When changing PLL output frequency (i.e. changing PLLM and/or PLLPS register) PCLK must not be selected as 8051 core clock

<sup>†</sup> When changing PLL output frequency (i.e. changing PLLM and/or PLLPS register) PCLK must not be selected as 8051 core clock



If all these five conditions are satisfied, a smooth transition from ring oscillator clock to the desired clock source ECLK or PCLK will automatically take place. Until then, the ring oscillator clock is supplied to the 8051 core. The 8051 starts execution as soon as it is released from reset using the oscillator clock, and then switches to another clock later on at run time. See Figure 5-4.

The described clock selection procedure is followed after External reset, WDT reset and aLPC Soft reset. Then, SST79LF008 will use the selected clock as long as software clock selection is not changed, ECLK is available, and PWRGOOD signal is high.

#### 5.3.3.1 Power Good Signal

PWRGOOD is a signal that indicates the system power is 'good'. The SST79LF008 device uses this signal as an external indicator of the availability of the ECLK clock. When PWRGOOD goes low, it indicates that the ECLK will be going away. Therefore SST79LF008 will automatically switch to internal ring oscillator as the clock source. In this case the ECLK must be available for at least two full cycles after PWRGOOD becomes low.



FIGURE 5-5: Power-On Sequence and Core Clock Switching



#### 5.3.4 Clock Switching in Low Power Modes

The SST79LF008 device has two low power modes: idle and Power Down mode.

Idle mode is entered by setting IDL bit in PCON register (Section 11.4). In idle mode the internal clock is gated off to the 8051CPU. In this mode, Clock selection controls cannot be changed and all peripheral modules continue to operate normally. Idle mode can be terminated by one of the reset events (see Table 5-2), or by any enabled interrupt (see Table 8-1). In any case the IDL bit is cleared in hardware on exit from idle mode. Clock selection, in the case when idle mode is terminated by a reset event, follows the procedure described in the Section 5.3.3. If Idle mode is terminated by an interrupt, 8051 uses the current clock selection and executes a call to the respective interrupt vector within one machine cycle after interrupt request is asserted. On return from the interrupt, the next instruction executed is the one following the instruction that sets IDL bit.

Power Down mode is entered by setting PD bit in PCON register (Section 11.4). In this mode the clock is stopped for 8051 CPU and most of the peripherals. At this time only

modules in Crystal Oscillator and LPC Interface domains may continue to operate (see Table 5-3). After 8051 enters into Power Down mode, hardware stops PLL and Ring Oscillator automatically. Power Down mode can be terminated by one of the reset events (see Table 5-2), or by any enabled wake up event (see Table 8-1). In any case PD bit is cleared in hardware on exit from Power Down mode. Clock selection, in the case when Power Down mode is terminated by a reset event, follows the procedure described in Section 5.3.3. Clock selection, in the case when Power Down mode is terminated by a wake event, is shown on Figure 5-4. After waking up from Power Down mode, the 8051 always uses RCLK as a core clock, and executes a call to the respective wake up interrupt vector within two machines cycles after the wake event. On return from the interrupt, the next instruction executed is the one following the instruction that sets PD bit. Independent of code execution flow, 8051 is then automatically switched by clock selection hardware to another clock source, such as ECLK or PCLK, if the source is stable and was selected by software before Power Down mode entry.





## 6.0 8051 EMBEDDED MICROCONTROLLER

The SST79LF008 device includes a high performance 8051 embedded microcontroller unit (MCU) as shown on Figure 1-1.

### 6.1 8051 MCU Enhancement

The 8051 embedded controller in SST79LF008 provides the following major improvements over the traditional 8051 controller:

- Increased performance: Adopts a selectable 6- or 3- clock machine cycle in lieu of the conventional 12-clock machine cycle, and supports up to 33 MHz operating frequency
- Increased program address space: Up to 128 KByte instead of conventional 64 KByte
- Increased on-chip SRAM: 2 KByte plus standard 256 Byte data memory
- Increased stack address space: Up to 2 KByte instead of conventional 256 Byte stack
- Dual Data Pointers: provide extra programming flexibility for 8051 code development
- Power-saving Operation: Idle and Power Down modes with multiple maskable wake-up sources
- Programmable clock source: internal ring oscillator (RCLK), external input clock (ECLK), or PLL clock (PCLK derived from ECLK, programmable frequency)

## 6.2 8051 Addressing Modes

The SST79LF008 supports two different addressing modes selectable by the AM1 bit in the ACON register. The 8051 core operates in either the traditional 8051 16-bit address mode (64 KByte address space) or in a 17-bit contiguous address mode (128 KByte address space).

#### 6.2.1 16-Bit Addressing Mode

In 16-bit addressing mode, code and data access is similar to the traditional 8051 memory access; all MCU instructions are opcode compatible and have identical byte count with the conventional 8051 controller. In this mode the MCU can access up to 64 KByte of program and data memory. The SST79LF008 defaults to 16-bit addressing mode following any reset event, which restarts 8051, as specified in Table 5-2.

#### 6.2.2 17-Bit Contiguous Addressing Mode

In 17-bit contiguous addressing mode, code and data access utilizes expanded 17-bit program counter and 17-bit data pointer; several branching and transfer instructions are modified as described below. In this mode the MCU can access up to 128 KByte of program and data memory. Selection of this mode is controlled by AM1 bit in ACON register, See also "6.5.1 Address Control Register (ACON)"

AM1 = ACON[1] = 1: Select 17-bit Contiguous Addressing Mode

AM1 = ACON[1] = 0: Select 16-bit Addressing Mode (reset value)

#### 6.2.2.1 8051 Instruction Set Modifications

All instruction opcodes are the same for the 16-bit and 17bit addressing modes. The operand size and encoding is also the same except for the ACALL, AJMP, LCALL and LJMP branch instructions and a MOV DPTR, #data instruction. These unique instructions will require the compiler to generate additional operands in 17-bit addressing mode relative to the conventional 16-bit addressing mode. Therefore 17-bit addressing mode support requires an assembler, compiler and linker to be specifically designed to properly handle the modified length of the above instructions.

The number of machine cycles per instruction may also be different because in 17-bit mode all branch instructions operates over entire 17-bit program counter, and all instructions which utilize the data pointer operates over 17-bit expanded DPTR = DPX[0]+DPH+DPL. However, changes in the number of machine cycles are transparent for the assembler and compiler.

The 8051 instructions modified in 17-bit addressing mode are specified in Table 6-1, which provides encoding, and byte numbers, as well as execution details for each instruction. The instruction assumes that extended 2 KByte stack mode is selected, see Section 6.5. Note, however, that 17bit contiguous addressing mode can be also used with traditional 8051 256 Byte stack; in this case extended stack pointer ESP:SP in Table 6-1 is replaced by standard stack pointer SP.



| TABLE | 6-1: 17-bit | Addressing | Mode-Spec | ific Instructions |
|-------|-------------|------------|-----------|-------------------|
|-------|-------------|------------|-----------|-------------------|

|                   | INSTRUCTION CODE                                                                                                                | NUMBER   |                          |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------|----------|--------------------------|
| MNEMONIC          | D7 D6 D5 D4 D3 D2 D1 D0                                                                                                         | of BYTES | OPERATION                |
| ACALL addr19      | a <sub>18</sub> a <sub>17</sub> a <sub>16</sub> 1 0 0 0 1                                                                       | 3        | (PC) <- (PC) + 3         |
|                   | $a_{15} a_{14} a_{13} a_{12} a_{11} a_{10} a_{9} a_{8}$                                                                         |          | (ESP:SP) <- (ESP:SP) + 1 |
|                   | $a_7 a_6 a_5 a_4 a_3 a_2 a_1 a_0$                                                                                               |          | ((ESP:SP)) <- (PC7-0)    |
|                   |                                                                                                                                 |          | (ESP:SP) <- (ESP:SP) + 1 |
|                   |                                                                                                                                 |          | ((ESP:SP)) <- (PC15-8)   |
|                   |                                                                                                                                 |          | (ESP:SP) <- (ESP:SP) + 1 |
|                   |                                                                                                                                 |          | ((ESP:SP)[0]) <- (PC16)  |
|                   |                                                                                                                                 |          | (PC16-0) <- addr16-0     |
| AJMP addr19       | a <sub>18</sub> a <sub>17</sub> a <sub>16</sub> 0 0 0 0 1                                                                       | 3        | (PC) <- (PC) + 3         |
|                   | a15 a14 a13 a12 a11 a10 a9 a8                                                                                                   |          | (PC16-0) <- addr116-0    |
|                   | $a_7 a_6 a_5 a_4 a_3 a_2 a_1 a_0$                                                                                               |          |                          |
| INC DPTR          | 1 0 1 0 0 0 1 1                                                                                                                 | 1        | (DPTR) <- (DPTR) + 1     |
| LCALL addr24      | 0 0 0 1 0 0 1 0                                                                                                                 | 4        | (PC) <- (PC) + 4         |
|                   | a <sub>23</sub> a <sub>22</sub> a <sub>21</sub> a <sub>20</sub> a <sub>19</sub> a <sub>18</sub> a <sub>17</sub> a <sub>16</sub> |          | (ESP:SP) <- (ESP:SP) + 1 |
|                   | a <sub>15</sub> a <sub>14</sub> a <sub>13</sub> a <sub>12</sub> a <sub>11</sub> a <sub>10</sub> a <sub>9</sub> a <sub>8</sub>   |          | ((ESP:SP)) <- (PC7-0)    |
|                   | a7 a6 a5 a4 a3 a2 a1 a0                                                                                                         |          | (ESP:SP) <- (ESP:SP) + 1 |
|                   |                                                                                                                                 |          | ((ESP:SP)) <- (PC15-8)   |
|                   |                                                                                                                                 |          | (ESP:SP) <- (ESP:SP) + 1 |
|                   |                                                                                                                                 |          | ((ESP:SP)[0]) <- (PC16)  |
|                   |                                                                                                                                 |          | (PC16-0) <- addr16-0     |
| LJMP addr24       | 0 0 0 0 0 0 1 0                                                                                                                 | 4        | (PC16-0) <- addr16-0     |
|                   | a23 a22 a21 a20 a19 a18 a17 a16                                                                                                 |          |                          |
|                   | a <sub>15</sub> a <sub>14</sub> a <sub>13</sub> a <sub>12</sub> a <sub>11</sub> a <sub>10</sub> a <sub>9</sub> a <sub>8</sub>   |          |                          |
|                   | $a_7$ $a_6$ $a_5$ $a_4$ $a_3$ $a_2$ $a_1$ $a_0$                                                                                 |          |                          |
| MOV DPTR, #data24 | 1 0 0 1 0 0 0 0                                                                                                                 | 4        | (DPTR) <- (#data16-0)    |
|                   | d <sub>23</sub> d <sub>22</sub> d <sub>21</sub> d <sub>20</sub> d <sub>19</sub> d <sub>18</sub> d <sub>17</sub> d <sub>16</sub> |          | DPX[0] <- #data16        |
|                   | d <sub>15</sub> d <sub>14</sub> d <sub>13</sub> d <sub>12</sub> d <sub>11</sub> d <sub>10</sub> d <sub>9</sub> d <sub>8</sub>   |          | DPH <- #data15-8         |
|                   | $d_7 \ d_6 \ d_5 \ d_4 \ d_3 \ d_2 \ d_1 \ d_0$                                                                                 |          | DPL <- #data7-0          |
| RET               | 0 0 1 0 0 0 1 0                                                                                                                 | 1        | (PC16) <- ((ESP:SP)[0])  |
|                   |                                                                                                                                 |          | (ESP:SP) – 1             |
|                   |                                                                                                                                 |          | (PC15-8) <- ((ESP:SP))   |
|                   |                                                                                                                                 |          | (ESP:SP) – 1             |
|                   |                                                                                                                                 |          | (PC7-0) <- ((ESP:SP))    |
|                   |                                                                                                                                 |          | (ESP:SP) - 1             |
| RETI              | 0 0 1 1 0 0 1 0                                                                                                                 | 1        | (PC16) <- ((ESP:SP)[0])  |
|                   |                                                                                                                                 |          | (ESP:SP) – 1             |
|                   |                                                                                                                                 |          | (PC15-8) <- ((ESP:SP))   |
|                   |                                                                                                                                 |          | (ESP:SP) - 1             |
|                   |                                                                                                                                 |          | (PC7-0) <- ((ESP:SP))    |
|                   |                                                                                                                                 |          | (ESP:SP) - 1             |

T6-1.1320



## 6.3 8051 Machine Cycle Control

For any 8051 core clock CCLK source specified in Section 5.3.2, the number of CCLK clocks within each instruction cycle can be selected by clock mode bit in 8051 clock control register.

#### 6.3.1 Clock Control Register (CLKCON)

| Location |               | 7 | 6                                                                                                                                                                                                  | 5         | 4 | 3    | 2     | 1        | 0        |  |  |  |
|----------|---------------|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---|------|-------|----------|----------|--|--|--|
| SFR      | Read          | _ | _                                                                                                                                                                                                  | _         | _ | SPR2 | CLKMD | T1SEL32K | T0SEL32K |  |  |  |
| AFH      | Write         | - | -                                                                                                                                                                                                  | -         | - |      |       |          |          |  |  |  |
|          | Reset         | Х | Х                                                                                                                                                                                                  | Х         | Х | 0    | 1     | 0        | 0        |  |  |  |
|          | Symbol        |   | Function                                                                                                                                                                                           | Function  |   |      |       |          |          |  |  |  |
|          | -             |   | Not imp                                                                                                                                                                                            | olemented |   |      |       |          |          |  |  |  |
|          | X Not defined |   |                                                                                                                                                                                                    |           |   |      |       |          |          |  |  |  |
|          | SPR2          |   | SPI clock Rate select bit 2<br>This bit together with SPR[1:0] bits controls SPI clock rate in master mode (see<br>Section 12.4.1)                                                                 |           |   |      |       |          |          |  |  |  |
|          | CLKMD         |   | 8051 clock Mode control bit<br>1: 6-clock mode (6 clocks in one instruction cycle)<br>0: 3-clock mode (3 clocks in one instruction cycle)                                                          |           |   |      |       |          |          |  |  |  |
|          | T1SEL32K      |   | Timer 1 clock Selection bit for event counter function<br>1: Timer 1 uses the 32.768KHz clock as event counter clock<br>0: Timer 1 uses external signal on the T1 input pin as event counter clock |           |   |      |       |          |          |  |  |  |
|          | T0SEL32K      |   | Timer 0 clock Selection bit<br>1: Timer 0 uses the 32.768KHz clock as event counter clock<br>0: Timer 0 uses external signal on the T0 input pin as event counter clock                            |           |   |      |       |          |          |  |  |  |

## 6.4 8051 Dual Data Pointers

SST79LF008 has two 17-bit data pointers sharing the same addresses in SFR space: both DPL registers share address 82H, both DPH registers share address 83H, and both DPX registers share address 93H. The DPTR selection bit (DPS) in AUXR1 register determines which of the two data pointers is accessed. When DPS = 0, DPTR0 is selected, and when DPS = 1, DPTR1 is selected. Quick

switching between the two data pointers can be accomplished by a single INC AUXR1 instruction. When switching between DPTR0 and DPTR1, all three DPX, DPH and DPL registers are switched respectively. The non-selected DPTR registers retain the values they have prior to switch. Refer to Figure 6-1 for illustration of dual data pointer organization.

| Location                                                                         |        | 7 | 6       | 5           | 4 | 3 | 2 | 1 | 0   |  |
|----------------------------------------------------------------------------------|--------|---|---------|-------------|---|---|---|---|-----|--|
| SFR                                                                              | Read   | - | -       | -           | - | - | - | - | DPS |  |
| A2H                                                                              | Write  |   |         |             |   |   |   |   |     |  |
|                                                                                  | Reset  | Х | Х       | X X X X X X |   |   |   |   |     |  |
|                                                                                  | Symbol |   | Functi  | on          |   |   |   |   |     |  |
| - Not implemented                                                                |        |   |         |             |   |   |   |   |     |  |
|                                                                                  | Х      |   | Not def | fined       |   |   |   |   |     |  |
| DPS DPTR Registers Selection bit<br>1: DPTR1 is selected<br>0: DPTR0 is selected |        |   |         |             |   |   |   |   |     |  |

#### 6.4.1 Auxiliary Register (AUXR1)



| 6.4.2 Data | Pointer | Low | Register | (DPL) |
|------------|---------|-----|----------|-------|
|------------|---------|-----|----------|-------|

| Location          |               | 7                           | 6           | 5              | 4          | 3            | 2            | 1    | 0    |
|-------------------|---------------|-----------------------------|-------------|----------------|------------|--------------|--------------|------|------|
| SFR               | Read          | DPL7                        | DPL6        | DPL5           | DPL4       | DPL3         | DPL2         | DPL1 | DPL0 |
| 82H               | Write         | -                           |             |                |            |              |              |      |      |
|                   | Reset         | 0                           | 0           | 0              | 0          | 0            | 0            | 0    | 0    |
|                   | Symbol        |                             | Functi      | on             |            |              |              |      |      |
|                   | DPL[7:0]      |                             | Low by      | te of DPTR     |            |              |              |      |      |
| 6.4.3 Data        | Pointer Hig   | gh Registe                  | r (DPH)     |                |            |              |              |      |      |
| Location          |               | 7                           | 6           | 5              | 4          | 3            | 2            | 1    | 0    |
| <b>SFR</b><br>83H | Read<br>Write | DPH7                        | DPH6        | DPH5           | DPH4       | DPH3         | DPH2         | DPH1 | DPH0 |
|                   | Reset         | 0                           | 0           | 0              | 0          | 0            | 0            | 0    | 0    |
|                   | Symbol        |                             | Functi      | on             |            |              |              |      |      |
|                   | DPH[7:0]      |                             | High b      | yte of DPTR    |            |              |              |      |      |
| 6.4.4 Data        | Pointer Ex    | tended Reg                  | gister (DP) | <b>(</b> )     |            |              |              |      |      |
| Location          |               | 7                           | 6           | 5              | 4          | 3            | 2            | 1    | 0    |
| SFR               | Read          | -                           | -           | -              | -          | -            | -            | -    | DPX0 |
| 93H               | Write         |                             |             |                |            |              |              |      |      |
|                   | Reset         | Х                           | Х           | Х              | Х          | Х            | Х            | Х    | 0    |
|                   | Symbol        |                             | Functi      | on             |            |              |              |      |      |
|                   | -             |                             | Not im      | plemented      |            |              |              |      |      |
|                   | Х             |                             | Not de      | fined          |            |              |              |      |      |
|                   | DPX[0]        |                             | Most s      | ignificant bit | of DPTR wh | en in 17-bit | addressing r | node |      |
|                   | L-J           |                             |             | 5              |            |              | J            |      |      |
|                   | A             | UXR1[0]                     | 1           |                | 1          | 1            |              | 1    |      |
|                   | Г             |                             |             |                |            |              |              |      |      |
|                   |               | DPS                         | >           | DPTR           |            | →///         |              |      |      |
|                   | L             |                             |             |                |            |              |              |      |      |
|                   |               |                             |             |                | DPTF       | 1            |              |      |      |
|                   |               | $DPS=1 \rightarrow DP^{-1}$ | TR=1        |                | DPTF       | 20           |              |      |      |
|                   |               | DPS=0 → DP                  |             |                |            |              |              |      |      |
|                   |               |                             | DF<br>93    |                | DPL<br>82H |              |              |      |      |
|                   |               |                             | L           |                |            |              |              |      |      |
|                   |               |                             |             |                |            | Exter        | nal Data Mem | ory  |      |

FIGURE 6-1: Dual Data Pointer Organization

### 6.5 8051 Stack Extension

The conventional 8051 stack is limited to 256Byte internal RAM. The SST79LF008 MCU provides either this conventional stack, or an extended 2 KByte stack (11-bit stack address). When extended stack is enabled by setting the Stack Address (SA) bit in the ACON register, the 2 KByte expanded RAM (XRAM) becomes the memory space used by all instructions that affect the stack. The 11-bit address is formed by concatenating the lower 3 bits of the Extended Stack Pointer (ESP), and the 8-bit Stack Pointer (SP).

When the SA bit is set, any overflow of SP from FFH to 00H will increment the ESP by 1, and any underflow of SP from 00h to FFH will decrement the ESP by 1. When SA = 0, ESP is ignored, but still read/write accessible, and SP is used as a conventional stack pointer.



| Location                                                                                                                                                                                                                                       |               | 7                                                                                                                                                                                                                                                                                              | 6          | 5               | 4 | 3 | 2    | 1    | 0    |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------------|---|---|------|------|------|--|--|--|
| SFR                                                                                                                                                                                                                                            | Read          | -                                                                                                                                                                                                                                                                                              | -          | -               | - | - | SA   | AM1  | -    |  |  |  |
| 9DH                                                                                                                                                                                                                                            | Write         |                                                                                                                                                                                                                                                                                                |            |                 |   |   |      |      |      |  |  |  |
|                                                                                                                                                                                                                                                | Reset         | Х                                                                                                                                                                                                                                                                                              | Х          | Х               | Х | Х | 0    | 0    | Х    |  |  |  |
|                                                                                                                                                                                                                                                | Symbol        |                                                                                                                                                                                                                                                                                                | Functi     | on              |   |   |      |      |      |  |  |  |
|                                                                                                                                                                                                                                                | -             |                                                                                                                                                                                                                                                                                                |            | Not implemented |   |   |      |      |      |  |  |  |
|                                                                                                                                                                                                                                                | Х             |                                                                                                                                                                                                                                                                                                | Not de     | fined           |   |   |      |      |      |  |  |  |
|                                                                                                                                                                                                                                                | SA            | Extended Stack Address Mode Enable bit<br>1: All stack instructions will utilize the 11-bit stack pointer ESP:SP formed by<br>concatenating the 3 least significant bits of ESP register with the SP register<br>0: All stack instructions will utilize the traditional 8-bit 8051 SP register |            |                 |   |   |      |      |      |  |  |  |
| AM1<br>Address Mode Control bit.<br>1: 17-bit Contiguous Addressing Mode<br>(128 KByte 8051 flash area and 896 KByte/7.0Mbit BIOS flash area)<br>0: 16-bit Addressing Mode<br>(64 KByte 8051 flash area and 960 KByte/7.5Mbit BIOS flash area) |               |                                                                                                                                                                                                                                                                                                |            |                 |   |   |      | )    |      |  |  |  |
| 6.5.2 Exte                                                                                                                                                                                                                                     | nded Stack    | Pointer Re                                                                                                                                                                                                                                                                                     | gister (ES | P)              |   |   |      |      |      |  |  |  |
| Location                                                                                                                                                                                                                                       |               | 7                                                                                                                                                                                                                                                                                              | 6          | 5               | 4 | 3 | 2    | 1    | 0    |  |  |  |
| SFR<br>9BH                                                                                                                                                                                                                                     | Read<br>Write | -                                                                                                                                                                                                                                                                                              | -          | -               | - | - | ESP2 | ESP1 | ESP0 |  |  |  |
|                                                                                                                                                                                                                                                | Reset         | Х                                                                                                                                                                                                                                                                                              | Х          | Х               | Х | Х | 0    | 0    | 0    |  |  |  |

|                   | Reset                                                                                                                                                                                                                                                                 | Х | Х      | Х  | Х | Х | 0 | 0 | 0 |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------|----|---|---|---|---|---|
|                   | Symbol                                                                                                                                                                                                                                                                |   | Functi | on |   |   |   |   |   |
| - Not implemented |                                                                                                                                                                                                                                                                       |   |        |    |   |   |   |   |   |
|                   | X Not defined                                                                                                                                                                                                                                                         |   |        |    |   |   |   |   |   |
|                   | ESP[2:0] Extended Stack Pointer<br>This register contains the upper 3 bits of the 11-bit extended stack pointer<br>stack<br>pointer allows a stack depth of 2 KBytes. Note that as the stack reaches the<br>the 2 KByte XRAM, it will wrap around to XRAM location 0. |   |        |    |   |   |   |   |   |

#### 6.5.3 Stack Pointer Register (SP)

| Location |       | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------|-------|-----|-----|-----|-----|-----|-----|-----|-----|
| SFR      | Read  | SP7 | SP6 | SP5 | SP4 | SP3 | SP2 | SP1 | SP0 |
| 81H      | Write | _   |     |     | -   |     | -   | -   |     |
|          | Reset | 0   | 0   | 0   | 0   | 0   | 1   | 1   | 1   |

### Symbol SP[7:0]

## Function

Stack Pointer

The stack pointer identifies current location of the stack. The stack pointer is incremented before every push operation (decremented after every pop operation). After reset SP defaults to 07H, and the stack starts at Internal RAM location 07H. Once

the 11-bit stack is enabled (SA = 1), this register is combined with the extended stack pointer (ESP) to form the 11-bit address, and the stack will start at XRAM location 07H.

Of course, software can relocate the stack to different portion of RAM as desired.



## 7.0 LPC INTERFACE

The SST79LF008 communicates with the host through the LPC bus. The SST79LF008 LPC interface implementation complies with LPC Interface Specification, Rev. 1.1, and always supports LPC I/O Read/Write cycle types. When LPCMODE bit of LPCMON register is '0', the SST79LF008 responds to Multi-Byte Firmware Memory Read/Write cycles on the LPC bus, and LPC Memory cycles are ignored. When LPCMODE bit of LPCMON register is '1', the SST79LF008 responds to Single-Byte LPC Memory Read/Write cycles on the LPC bus, and LPC Firmware Memory Read/Write cycles on the LPC bus, and LPC Memory Read/Write cycles are ignored.

SST79LF008 utilizes all required LPC signals: LAD[3:0], LFRAME#, LRESET#, and LCLK, as well as the following optional LPC signals: SERIRQ, CLKRUN#, and LPCPD# (note that CLKRUN#, and LPCPD# signals share pins with GPIO, and should be properly selected to enable the respective function).

The SST79LF008 flash memory can be read, written, erased and reprogrammed via LPC interface. The flash memory is divided into blocks and sectors that can be erased independently. Flash memory blocks can be protected to prevent accidental modification. All flash commands are interpreted by the device command interface. An on-chip memory controller simplifies the process of programming or erasing the memory by taking care of all of the special operations that are required to update the memory contents. The end of a program or erase operation can be detected by the LPC Host software via flash memory status register.

## 7.1 LPC Bus Transfer

The SST79LF008 LPC interface implementation complies with LPC Interface Specification, Rev. 1.1, and always supports LPC I/O Read/Write cycle types. When LPCMODE bit of LPCMON register is '0', the SST79LF008 responds to Multi-Byte Firmware Memory Read/Write cycles on the LPC bus, and LPC Memory cycles are ignored. When LPCMODE bit of LPCMON register is '1', the SST79LF008 responds to Single-Byte LPC Memory Read/Write cycles on the LPC bus, and LPC Firmware Memory cycles are ignored. Table 7-1 summarize the size of transfers supported by the SST79LF008.

| TABLE | 7-1: Transfer Size Supported by the |
|-------|-------------------------------------|
|       | SST79LF008                          |

| Сусіе Туре            | Size of Transfer       |
|-----------------------|------------------------|
| Firmware Memory Read  | 1, 2, 4, 16, 128 bytes |
| Firmware Memory Write | 1, 2, 4 bytes          |
| LPC Memory Read       | 1 byte                 |
| LPC Memory Write      | 1 byte                 |
| I/O Read              | 1 byte                 |
| I/O Write             | 1 byte                 |

T7-1.0 1320

The LPC bus transfer uses four data signals LAD[3:0], one control signal LFRAME#, and LPC clock LCLK. Reset signal LRESET# will put the LPC interface module into a known reset state. The data signals, control signal and clock are designed to be compatible with PCI electrical specifications. The LPC interface operates with a clock speed of 33 MHz.

## 7.2 LPC Bus Cycles

The start of any LPC cycle is indicated by the LPC Host via active low LFRAME# signal. The START value for LPC cycle determines whether it is Firmware Memory or LPC Memory/LPC I/O cycle — see Table 7-2 (the START value is the LAD[3:0] value latched on the last clock before the host chipset drives LFRAME# signal inactive from low-to-high).

 TABLE
 7-2: Firmware and LPC Memory Cycles

 START Field Definition

| START<br>Value | Definition                                                                                                     |
|----------------|----------------------------------------------------------------------------------------------------------------|
| 0000           | Start of a LPC Memory Read/Write cycle or I/O<br>Read/Write (next field specifies cycle type and<br>direction) |
| 1101           | Start of a cycle for Firmware Memory Read                                                                      |
| 1110           | Start of a cycle for Firmware Memory Write                                                                     |
|                |                                                                                                                |

T7-2.0 1320

See the following sections for detailed examples of Firmware Memory, LPC memory, and LPC I/O cycles. See Section 23 for the LPC related configuration options available in SST79LF008 device.



#### 7.2.1 Firmware Memory Cycles

|                | ••••••••           |                                |                       |                                                                                                                                                                                                                      |
|----------------|--------------------|--------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clock<br>Cycle | Field<br>Name      | Field<br>Contents <sup>1</sup> | Direction<br>LAD[3:0] | Comments                                                                                                                                                                                                             |
| 1              | START              | 1101                           | IN                    | LFRAME# must be active (low) for the part to respond. Only the last start field (before LFRAME# transitioning high) should be recognized. The START field contents indicate a Firmware Memory Read cycle.            |
| 2              | IDSEL              | 0000 or<br>0001                | IN                    | Indicates which SST79LF008 device should respond. If the IDSEL (ID select) field matches the value specified by ID input pin, then that par-<br>ticular device will respond to the bus cycle.                        |
| 3-9            | MADDR              | AAAA                           | IN                    | These seven clock cycles make up the 28-bit memory address.<br>AAAA is one nibble of the entire address. Addresses are transferred<br>most-significant nibble first.                                                 |
| 10             | MSIZE              | YYYY                           | IN                    | Indicates transfer size.<br>Device will execute multi-byte read of $2^{YYYY}$ bytes. SST79LF008 supports only YYYY = 0, 1, 2, 4, 7 (i.e., read 1, 2, 4, 16, 128 bytes).                                              |
| 11             | TAR0               | 1111                           | IN, then<br>Float     | In this clock cycle, the host has driven the bus to all '1's and then floats the bus, prior to the next clock cycle. This is the first part of the bus "turnaround cycle."                                           |
| 12             | TAR1               | 1111 (float)                   | Float, then<br>OUT    | The SST79LF008 takes control of the bus during this cycle.                                                                                                                                                           |
| 13             | RSYNC <sup>2</sup> | 0000                           | OUT                   | During this clock cycle, the SST79LF008 will generate a "ready-sync" (RSYNC) indicating that the least-significant nibble of the least-significant byte will be available during the next clock cycle.               |
| 14-A           | DATA               | DDDD                           | OUT                   | $A = (13+2^{n+1}); n = MSIZE$                                                                                                                                                                                        |
|                |                    |                                |                       | Least significant nibbles outputs first.                                                                                                                                                                             |
| (A+1)          | TAR0               | 1111                           | OUT, then<br>Float    | In this clock cycle, the SST79LF008 has driven the bus to all ones<br>and then floats the bus prior to the next clock cycle. This is the first<br>part of the bus "turnaround cycle". A = $(13+2^{n+1})$ ; n = MSIZE |
| (A+2)          | TAR1               | 1111 (float)                   | Float, then<br>IN     | The host resumes control of the bus during this cycle. A = $(13+2^{n+1})$ ; n = MSIZE                                                                                                                                |

#### TABLE 7-3: Firmware Memory Read Cycle Field Definitions

1. Field contents are valid on the rising edge of the present clock cycle

2. Between TAR1 and RSYNC cycles SST79LF008 may insert a number of "long- wait-sync" cycles (LWSYNC = 0110b), indicating that data is not ready, yet.



T7-3.0 1320



| TABLE | 7-4: Firmware Memory Write Cycle Field Definitions |
|-------|----------------------------------------------------|
|-------|----------------------------------------------------|

| Clock<br>Cycle | Field<br>Name | Field<br>Contents <sup>1</sup> | Direction<br>LAD[3:0] | Comments                                                                                                                                                                                                      |
|----------------|---------------|--------------------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1              | START         | 1110                           | IN                    | LFRAME# must be active (low) for the part to respond. Only the last start field (before LFRAME# transitioning high) should be recognized. The START field contents indicate a Firmware Memory Write cycle.    |
| 2              | IDSEL         | 0000 or<br>0001                | IN                    | Indicates which SST79LF008 device should respond. If the IDSEL (ID select) field matches the value specified by ID input pin, then that particular device will respond to the bus cycle.                      |
| 3-9            | MADDR         | AAAA                           | IN                    | These seven clock cycles make up the 28-bit memory address. AAAA is one nib-<br>ble of the entire address. Addresses are transferred most-significant nibble first.                                           |
| 10             | MSIZE         | YYYY                           | IN                    | Indicates transfer size.<br>Device will execute multi-byte write of $2^{YYYY}$ bytes. SST79LF008 supports only YYYY = 0, 1, 2 (i.e., write 1, 2, 4 bytes.                                                     |
| 11-A           | DATA          | DDDD                           | IN                    | A = $(10+2^{n+1})$ ; n = MSIZE Least significant nibble entered first.                                                                                                                                        |
| (A+1)          | TAR0          | 1111                           | IN, then<br>Float     | In this clock cycle, the master drives the bus to all '1's, and then floats the bus prior to the next clock cycle. This is the first part of the bus "turnaround cycle." $A = (10+2^{n+1})$ ; n = MSIZE       |
| (A+2)          | TAR1          | 1111 (float)                   | Float, then<br>OUT    | The SST79LF008 takes control of the bus during this cycle.<br>A = $(10+2^{n+1})$ ; n = MSIZE                                                                                                                  |
| (A+3)          | RSYNC         | 0000                           | OUT                   | The SST79LF008 outputs the "ready-sync" value 0000b, indicating that it has received data or a flash command.<br>A = $(10+2^{n+1})$ ; n = MSIZE                                                               |
| (A+4)          | TAR0          | 1111                           | OUT, then<br>Float    | In this clock cycle, the SST79LF008 drives the bus to all '1's, and then floats the bus prior to the next clock cycle. This is the first part of the bus "turnaround cycle".<br>$A = (10+2^{n+1}); n = MSIZE$ |
| (A+5)          | TAR1          | 1111 (float)                   | Float, then<br>IN     | The host resumes control of the bus during this cycle.<br>A = $(10+2^{n+1})$ ; n = MSIZE                                                                                                                      |

1. Field contents are valid on the rising edge of the present clock cycle

T7-4.0 1320







T7-5.0 1320

Advance Information

#### 7.2.2 LPC Memory Cycles

| Clock<br>Cycle | Field<br>Name      | Field<br>Contents <sup>1</sup> | Direction<br>LAD[3:0] | Comments                                                                                                                                                                                                                                                         |
|----------------|--------------------|--------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1              | START              | 0000                           | IN                    | Indicates start of a cycle. LFRAME# must be active (low) for the part to respond. Only the last start field (before LFRAME# transitioning high) should be recognized.                                                                                            |
| 2              | CYCTYPE<br>+ DIR   | 010xb                          | IN                    | Type of cycle and direction of transfer. Field contents indicates an LPC Memory Read cycle.                                                                                                                                                                      |
| 3-10           | ADDR               | ΑΑΑΑ                           | IN                    | Address Phase for Memory Cycle. LPC protocol supports a 32-bit address phase. AAAA is one nibble of the entire address. Addresses are trans-<br>ferred most-significant nibble first. The SST79LF008 encodes ID and register space access in the address fields. |
| 11             | TAR0               | 1111                           | IN, then<br>Float     | In this clock cycle, the host drives the bus to all '1's, and then floats the bus.<br>This is the first part of the bus "turnaround cycle."                                                                                                                      |
| 12             | TAR1               | 1111 (float)                   | Float, then<br>OUT    | The SST79LF008 takes control of the bus during this cycle.                                                                                                                                                                                                       |
| 13             | RSYNC <sup>2</sup> | 0000                           | OUT                   | The SST79LF008 outputs the "ready-sync" value 0000b indicating that data will be available during the next clock cycle.                                                                                                                                          |
| 14             | DATA               | D3D2D1D0                       | OUT                   | This field is the least-significant nibble of the data byte.                                                                                                                                                                                                     |
| 15             | DATA               | D7D6D5D4                       | OUT                   | This field is the most-significant nibble of the data byte.                                                                                                                                                                                                      |
| 16             | TAR0               | 1111                           | OUT, then<br>Float    | In this clock cycle, the host drives the bus to all '1's, and then floats the bus.<br>This is the first part of the bus "turnaround cycle."                                                                                                                      |
| 17             | TAR1               | 1111 (float)                   | Float, then<br>IN     | The host resumes control of the bus during this cycle.                                                                                                                                                                                                           |

#### TABLE 7-5: LPC Memory Read Cycle Field Definitions

1. Field contents are valid on the rising edge of the present clock cycle

2. Between TAR1 and RSYNC cycles SST79LF008 may insert a number of "long- wait-sync" cycles (LWSYNC = 0110b), indicating that data is not ready, yet.







### TABLE 7-6: LPC Memory Write Cycle Field Definitions

| Clock<br>Cycle | Field<br>Name    | Field<br>Contents <sup>1</sup> | Direction<br>LAD[3:0] | Comments                                                                                                                                                                                                                                                    |
|----------------|------------------|--------------------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1              | START            | 0000                           | IN                    | Indicates start of a cycle. LFRAME# must be active (low) for the part to respond. Only the last start field (before LFRAME# transitioning high) should be recognized.                                                                                       |
| 2              | CYCTYPE<br>+ DIR | 011xb                          | IN                    | Type of cycle and direction of transfer. Field contents indicates an LPC Memory Write cycle.                                                                                                                                                                |
| 3-10           | ADDR             | ΑΑΑΑ                           | IN                    | Address Phase for Memory Cycle. LPC protocol supports a 32-bit address phase. AAAA is one nibble of the entire address. Addresses are transferred most-significant nibble first. The SST79LF008 encodes ID and register space access in the address fields. |
| 11             | DATA             | D3D2D1D0                       | IN                    | This field is the least-significant nibble of the data byte.                                                                                                                                                                                                |
| 12             | DATA             | D7D6D5D4                       | IN                    | This field is the most-significant nibble of the data byte.                                                                                                                                                                                                 |
| 13             | TAR0             | 1111                           | IN,<br>then Float     | In this clock cycle, the host drives the bus to all '1's, and then floats the bus.<br>This is the first part of the bus "turnaround cycle."                                                                                                                 |
| 14             | TAR1             | 1111 (float)                   | Float,<br>then OUT    | The SST79LF008 takes control of the bus during this cycle.                                                                                                                                                                                                  |
| 15             | RSYNC            | 0000                           | OUT                   | The SST79LF008 outputs the "ready-sync" value 0000b indicating that it has received data or a flash command.                                                                                                                                                |
| 16             | TAR0             | 1111                           | OUT, then<br>Float    | In this clock cycle, the host drives the bus to all '1's and then floats the bus.<br>This is the first part of the bus "turnaround cycle."                                                                                                                  |
| 17             | TAR1             | 1111 (float)                   | Float,<br>then IN     | The host resumes control of the bus during this cycle.                                                                                                                                                                                                      |

1. Field contents are valid on the rising edge of the present clock cycle





T7-6.0 1320



## 7.2.3 LPC I/O Cycles

| Clock<br>Cycle | Field<br>Name    | Field<br>Contents <sup>1</sup> | Direction<br>LAD[3:0] | Comments                                                                                                                                                                               |
|----------------|------------------|--------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1              | START            | 0000                           | IN                    | Indicates start of a cycle. LFRAME# must be active (low) for the part to respond. Only the last start field (before LFRAME# transitioning high) should be recognized.                  |
| 2              | CYCTYPE<br>+ DIR | 000xb                          | IN                    | Type of cycle and direction of transfer. Field contents indicates an LPC I/O Read cycle.                                                                                               |
| 3-6            | ADDR             | AAAA                           | IN                    | Address Phase for Memory Cycle. LPC protocol supports a 16-bit<br>address phase. AAAA is one nibble of the entire address. Addresses<br>are transferred most-significant nibble first. |
| 7              | TAR0             | 1111                           | IN, then<br>Float     | In this clock cycle, the host drives the bus to all '1's, and then floats the bus. This is the first part of the bus "turnaround cycle."                                               |
| 8              | TAR1             | 1111 (float)                   | Float, then<br>OUT    | The SST79LF008 takes control of the bus during this cycle.                                                                                                                             |
| 9              | RSYNC            | 0000                           | OUT                   | The SST79LF008 outputs the "ready-sync" value 0000b indicating that data will be available during the next clock cycle.                                                                |
| 10             | DATA             | D3D2D1D0                       | OUT                   | This field is the least-significant nibble of the data byte.                                                                                                                           |
| 11             | DATA             | D7D6D5D4                       | OUT                   | This field is the most-significant nibble of the data byte.                                                                                                                            |
| 12             | TAR0             | 1111                           | OUT, then<br>Float    | In this clock cycle, the host drives the bus to all '1's and then floats the bus. This is the first part of the bus "turnaround cycle."                                                |
| 13             | TAR1             | 1111 (float)                   | Float, then<br>IN     | The host resumes control of the bus during this cycle.                                                                                                                                 |

#### TABLE 7-7: LPC I/O Read Cycle Field Definitions

1. Field contents are valid on the rising edge of the present clock cycle







| Clock<br>Cycle | Field<br>Name    | Field<br>Contents <sup>1</sup> | Direction<br>LAD[3:0] | Comments                                                                                                                                                                               |  |
|----------------|------------------|--------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1              | START            | 0000                           | IN                    | Indicates start of a cycle. LFRAME# must be active (low) for the part to respond. Only the last start field (before LFRAME# transitioning high) should be recognized.                  |  |
| 2              | CYCTYPE<br>+ DIR | 001xb                          | IN                    | Type of cycle and direction of transfer. Field contents indicates an LP I/O Write cycle.                                                                                               |  |
| 3-6            | ADDR             | AAAA                           | IN                    | Address Phase for Memory Cycle. LPC protocol supports a 16-bit<br>address phase. AAAA is one nibble of the entire address. Addresses<br>are transferred most-significant nibble first. |  |
| 7              | DATA             | D3D2D1D0                       | IN                    | This field is the least-significant nibble of the data byte.                                                                                                                           |  |
| 8              | DATA             | D7D6D5D4                       | IN                    | This field is the most-significant nibble of the data byte.                                                                                                                            |  |
| 9              | TAR0             | 1111                           | IN, then<br>Float     | In this clock cycle, the host drives the bus to all '1's, and then floats the bus. This is the first part of the bus "turnaround cycle."                                               |  |
| 10             | TAR1             | 1111 (float)                   | Float, then<br>OUT    | The SST79LF008 takes control of the bus during this cycle.                                                                                                                             |  |
| 11             | RSYNC            | 0000                           | OUT                   | The SST79LF008 outputs the "ready-sync" value 0000b indicating that it has received data.                                                                                              |  |
| 12             | TAR0             | 1111                           | OUT, then<br>Float    | In this clock cycle, the host drives the bus to all '1's, and then floats the bus. This is the first part of the bus "turnaround cycle."                                               |  |
| 13             | TAR1             | 1111 (float)                   | Float, then<br>IN     | The host resumes control of the bus during this cycle.                                                                                                                                 |  |
|                |                  | •                              |                       | T7-8.0 1320                                                                                                                                                                            |  |

1. Field contents are valid on the rising edge of the present clock cycle



FIGURE 7-6: LPC I/O Write Cycle Waveform



### 7.3 LPC Flash Command Definitions

All memory write operations are interpreted by the LPC Flash command interface. Commands consist of one or more sequential bus write operations. After power-up or reset, the device enters into the read array mode. For power-up and reset details, see Section 5.2. The commands are summarized in Table 7-9. For detail of each command, refer to the sections below.

| TABLE | 7-9: LPC Flash Command Definiti | ons <sup>1</sup> |
|-------|---------------------------------|------------------|
|-------|---------------------------------|------------------|

|                                  | Bus Cycles |       | First Bu | s Cycle    | Seco  | nd Bus ( | Cycle |       |
|----------------------------------|------------|-------|----------|------------|-------|----------|-------|-------|
| Command                          | Required   | Oper  | Addr     | Data       | Oper  | Addr     | Data  | Notes |
| Read Array/Reset                 | 1          | Write | Х        | FFH        |       |          |       |       |
| Read Device ID<br>Read Unique ID | ≥ 2        | Write | Х        | 90H        | Read  | IA       | ID    | 2,3   |
| Read Status Register             | 2          | Write | Х        | 70H        | Read  | Х        | SRD   | 3     |
| Clear Status Register            | 1          | Write | Х        | 50H        |       |          |       |       |
| Sector Erase                     | 2          | Write | Х        | 30H        | Write | SA       | D0H   | 4     |
| Block Erase                      | 2          | Write | Х        | 20H        | Write | BA       | D0H   | 4     |
| Program                          | 2          | Write | Х        | 40H or 10H | Write | WA       | WD    | 4     |
| Erase Suspend                    | 1          | Write | Х        | B0H        |       |          |       |       |
| Erase Resume                     | 1          | Write | Х        | D0H        |       |          |       |       |
| User Unique ID Program           | 2          | Write | Х        | A5H        | Write | WA       | WD    | 5     |
| User Unique ID Program Lockout   | 2          | Write | Х        | 85H        | Write | Х        | 00H   |       |
| Enter UNVR(3K OTP) / Enter ENVR  | 2          | Write | Х        | 60H        | Write | Х        | 76H   | 6     |
| Force LPC Soft Reset             | 2          | Write | Х        | 65H        | Write | Х        | 8AH   | 7     |
| Release LPC Soft Reset           | 2          | Write | Х        | 6AH        | Write | Х        | 79H   | 7     |

T7-9.0 1320

1. X = Any valid address within the device main flash memory array address space (FFF0 0000H to FFFF FFFFH).

IA = Device Identification (ID) address/Unique ID address

SA/BA = Address of sector or block being erased (any valid address within the respective sector/block)

WA = Address of memory location to be written to

WD = Data written to address WA

ID = Data read from Device identifier codes or Unique ID

- 2. Read operations, following the Read Device/Unique ID command, access either Manufacturer ID, or Device ID, or Unique ID. Valid Manufacturer and Device ID addresses are FFFC 0000H and FFFC 0001H, respectively.
  - Valid address range for SST Pre-Programmed 8-byte Factory Unique ID is from FFFC 0180H to FFFC 0187H.

Valid address range for User Programmable 24-byte Unique ID is from FFFC 0188H to FFFC 019FH.

3. Subsequent reads continue to return ID or Status data until another valid command is issued.

4. The sector or block to be erased or programmed must not be write-locked, otherwise the operation will fail.

5. Valid User Programmable Unique ID addresses are from FFFC 0188H to FFFC 019FH.

6. After enter ENVR/UNVR command is executed

Valid address for 4K ENVR area is from FFF0 0000H to FFF0 0FFFH.

Valid address for 3K OTP UNVR area is from FFF0 1000H to FFF0 1BFFH.

7. These 2 commands are not standard flash memory control commands. Do not use these commands unless the KBC firmware and BIOS are corrupted.

Two LPC write cycles within 2-cycle command must be consecutive. The command sequence has to be restarted from the first cycle, if the second cycle data is incorrect, the second cycle is a read from memory array, or the second cycle is a read/write access to LPC memory mapped registers. For more information on LPC memory mapped registers, see Section 7.6. However, if the second cycle is aborted or contains invalid fields, it will be ignored, and the command sequence does not need to be restarted. See Section 7.4 for LPC abort mechanisms and invalid fields. All address ranges defined for LPC flash commands are specified as 32-bit system memory addresses, and are valid when SST79LF008 is used as a boot firmware memory device (low level is applied to ID input pin). When the SST79LF008 is not a boot device, the respective addresses will be changed according to Multiple Device Selection mechanism described in Section 7.5.

SRD = Data read from Status Register



#### 7.3.1 Read Array Command

After Power-On, Brown-Out, External, WDT, or aLPC Soft Reset, the device defaults to the read array mode. The read operation can also be initiated by issuing the Read Array/Reset Command. The device remains available for main flash memory array reads until another command is written.

Once an internal Program/Erase operation starts, the device will not recognize the Read Array/Reset command until the operation is completed, unless the erase operation is suspended via an Erase Suspend command as described in Section 7.3.7.

#### 7.3.2 Read Device Identifier Command

The Read ID operation is initiated by writing the Read Device ID command. Following the write of this command, the device outputs the manufacturer and device ID data from the addresses shown in Table 7-10. Write any other valid command to the device to terminate the Read ID operation.

## Mobile Platform Controller 8 Mbit LPC Firmware Flash SST79LF008

|                            | Address    | Data |
|----------------------------|------------|------|
| Manufacturer's ID<br>(SST) | FFFC 0000H | BFH  |
| Device ID<br>(SST79LF008)  | FFFC 0001H | F0H  |

#### TABLE 7-10: Product Identification

T7-10.0 1320

#### 7.3.3 Read Status Register Command

The Status register provides information on the current or previous Program or Erase operation. The Status register may be read to determine when a program or sector/block erase command completes, and whether the operation completed successfully. The Status register may be read at any time by issuing the Read Status Register Command.

After writing this command, all subsequent read operations within the device main flash memory array will return the data from the status register until another valid command is written. The Status Register bits are summarized in Register 7.3.3.1.

|        | 7                                                                                                                                                                                                                                                                                                                                                                             | 6           | 5 | 4 | 3 | 2 | 1   | 0 |  |  |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---|---|---|---|-----|---|--|--|
| Name   | WSMS                                                                                                                                                                                                                                                                                                                                                                          | ESS         | - | - | - | - | BPS | - |  |  |
| Reset  | 1                                                                                                                                                                                                                                                                                                                                                                             | 0           | 0 | 0 | 0 | 0 | 0   | 0 |  |  |
| Bit    | Description                                                                                                                                                                                                                                                                                                                                                                   | Description |   |   |   |   |     |   |  |  |
| 7      | Write State Machine Status<br>Check WSMS to determine erase or program completion.<br>1 = Ready<br>0 = Busy                                                                                                                                                                                                                                                                   |             |   |   |   |   |     |   |  |  |
| 6      | Erase Suspend Status<br>1 = Erase Suspended<br>0 = Erase in progress/completed                                                                                                                                                                                                                                                                                                |             |   |   |   |   |     |   |  |  |
| 1      | <ul> <li>Block Protect Status</li> <li>The Block Write-Lock bit is interrogated only after erase or program command is issued. It informs the system whether or not the selected block is locked. This bit does not provide a continuous indication of write-lock bit value.</li> <li>1 = Write-lock bit is set (operation aborted)</li> <li>0 = Block is unlocked</li> </ul> |             |   |   |   |   |     |   |  |  |
| 5:2, 0 | Reserved for                                                                                                                                                                                                                                                                                                                                                                  | future use  |   |   |   |   |     |   |  |  |

#### 7.3.3.1 Flash Memory Status Register

#### 7.3.4 Clear Status Register Command

The Clear Status Register command can be used to reset the BPS bit in the Status register to '0'. This bit does not automatically return to '0' when a new Program or Erase command is issued. Therefore, it should be cleared by issuing the Clear Status Register Command before attempting a new Program or Erase command. Device Power-On, Brown-Out, External, WDT, or aLPC Soft Reset will return Status Register to its reset value, and clear BPS to '0'.

T7-10.0 1320

## 7.3.5 Sector Erase Command and Block Erase Command

The Erase Command operates on one sector or block at a time. This command requires an arbitrary address within the targeted sector or block (SA or BA) to be specified in the second bus cycle. Note that a Sector/Block Erase operation changes all Sector/Block byte data to FFH. If a read operation is performed within the main flash memory array after issuing the erase command, the device will automatically output Status Register data. The system can poll the Status Register in order to verify the completion of the Sector/Block Erase operation. If a Sector/Block Erase is attempted on a locked block, the operation will fail and the data in the Sector/Block will not be changed. In this case, the Status Register will report the error (BPS = 1). During the Block Erase or Sector Erase operation, the device will only accept the Read Status Register or the Erase Suspend commands. All other commands will be ignored until the operation is completed.

#### 7.3.6 Program Command

The Program Command writes data (WD) specified in the second bus cycle to the consecutive flash memory locations starting with the specified address (WA). The data size can be specified as 1, 2, or 4 bytes for Firmware Memory cycles, and 1 byte only for LPC memory cycles. After issuing Program command the device automatically outputs the Status Register data when read within the main flash memory array. The system can poll the Status Register in order to verify the completion of the Program operation. If a Program operation is attempted on a locked block, the operation will fail and the data in the addressed byte will not be changed. In this case, the Status Register will report the error (BPS = 1). During the Program operation, the device will only accept the Read Status Register command. All other commands will be ignored until the operation is completed.

## 7.3.7 Erase Suspend Command and Erase Resume Commands

The Erase Suspend command allows Sector or Block Erase interruption in order to read or program data in another block of memory. Once the Erase Suspend command is executed, the device will suspend any in-progress Erase operation within time  $T_{ES}$ . See Table 24-8. The device outputs status register data, when read within the main flash memory array, after the Erase Suspend command is written. After erase operation is actually suspended, the device will set the Status Register bit ESS = 1. Thus, the system can determine whether the erase opera-



#### Advance Information

tion has been suspended (WSMS = 1 and ESS = 1) or completed (WSMS = 1 and ES = 0) by polling the Status Register.

After a successful suspend, a Read Memory Array command may be issued to read data from a block other than the suspended block. A Program command may also be issued while Erase is suspended to program data in memory locations other than the sector or block currently in the Erase Suspend mode. If a Read Array command is written to an address within the suspended Sector/Block, this may result in reading invalid data. If a Program command is written to an address within the suspended Sector/Block, the command is acknowledged but ignored. Other valid commands while an erase is suspended include Read Status Register, Read Device ID, and Erase Resume.

The Erase Resume command resumes the erase operation in the suspended sector or block. After the Erase Resume command is written, the device will continue the erase operation. Erase cannot resume until any program operations initiated during erase suspend have completed. Suspended operations cannot be nested. That is, the system needs to complete/resume any previously suspended operation before a new operation can be suspended. Once the Erase Resume command is issued, the subsequent bus read operations within the main flash memory array read the status register.

## 7.3.8 User Unique ID Read, Program and Lockout Commands

The 256-bits (32 bytes) of the SST79LF008 Unique ID space are divided into two segments. One 64-bit segment is programmed at SST with a unique 64-bit number, which is unchangeable. The other 192-bit segment is a one time programmable segment (OTP) which is left blank for customers to program as desired. Once the customer segment is programmed, it can be locked to prevent reprogramming. Note that regardless of whether or not the Unique ID is locked, neither of the Unique ID segments can be erased.

In order to read the Unique ID information, the user can issue a Read Unique ID command to the device. At this point the device enters the Read Device/Unique ID mode. The Unique ID information can be read at the following memory addresses (IA):

- FFFC 0180H to FFFC 0187H SST Factory Pre-Programmed ID (8 bytes – 64 bit).
- FFFC 0188H to FFFC 019FH User Programmed Unique ID (24 bytes 192bit).



A Read Array/Reset command must then be issued to the device in order to exit the "Read Device/Unique ID" mode and return to read array mode.

An alternative method to read the Unique ID information without switching from read array mode is to read the respective registers located in the firmware flash memory register space described in Section 7.6. In this case the Unique ID information can be retrieved in read array mode at the following register addresses:

- FFBC 0180H to FFBC 0187H SST Pre-Programmed Device ID Segment (8 bytes – 64bit).
- FFBC 0188H to FFBC 019FH User Programmed Unique ID Segment (24bytes 192bit).

In order to Program the Unique ID, a Program Unique ID command should be issued with the address (WA) in the range of FFFC 0188H to FFFC 019FH. Processing of this command is similar to the main flash array program command described above. In order to protect Unique ID from corruption, Unique ID Program Lockout command should be used.

#### 7.3.9 Enter UNVR (3K OTP) / Enter ENVR Commands

The Enter UNVR/ENVR access mode command is used to access 3 KByte OTP UNVR and 4 KByte flash ENVR. Once the Enter UNVR/Enter ENVR command is issued, the LPC Host can read ENVR information at addresses FFF0 0000H to FFF0 0FFFH in LPC address space and read UNVR at addresses FFF0 1000H to FFF0 1BFFH in LPC address space. The LPC Host can also erase/program ENVR as well as program UNVR using the same Sector Erase and Program commands as for the main flash array.

A Read Array/Reset command must be issued to the device in order to exit the UNVR/ENVR access mode and return to read main flash array mode.

#### 7.3.10 Force / Release LPC Soft Reset Commands

The Force LPC Soft Reset command is used to put 8051 into LPC Soft Reset state and unconditionally release the flash memory bus to the LPC Host. This command aborts KBC operation, and it is not recommended, unless KBC firmware and BIOS code are both corrupted.

The Release LPC Soft Reset command is used to restart 8051 code execution and KBC operations after LPC Soft reset.

**Note.** In addition to Release command, the LPC Soft Reset state is also terminated by Power-On, Brown-Out, External, WDT or aLPC Soft Reset, as well as by LPC Interface Reset (LRESET#) and LPC Power Down (LPCPD#) signals.

# 7.4 LPC Abort Mechanism and Invalid Fields

If LFRAME# is driven low for one or more clock cycles after the start of a bus cycle, the cycle will be terminated. The host may drive the LAD[3:0] with 1111b (ABORT nibble) to return the interface to ready mode. The ABORT only affects the current bus cycle. For a multi-cycle command sequence, such as the Erase or Program commands, ABORT doesn't interrupt the entire command sequence, only the current bus cycle of the command sequence. The host can re-send the bus cycle for the aborted command and continue the command sequence after the device is ready again.

During an on-going LPC bus cycle, the SST79LF008 will not explicitly indicate that it has received invalid field sequences. The response to specific invalid fields or sequences is explained in Sections 7.4.1 and 7.4.2.

#### 7.4.1 Response to Invalid Fields for Firmware Memory Cycle

**ID mismatch**: The SST79LF008 compares ID bits in the IDSEL field with the ID value specified by the SST79LF008 input ID pin. If there is a mismatch, the device will ignore the cycle. See Multiple Device Selection, Section 7.5 for details.

Address out of range: The address sequence is 7 fields long (28 bits) for Firmware Memory bus cycles. Only address bits  $A_0$  to  $A_{19}$  and  $A_{22}$  are decoded by the SST79LF008. Address  $A_{22}$  has the special function of directing reads and writes to the flash core ( $A_{22} = 1$ ) or to the register space ( $A_{22} = 0$ ).

**Invalid MSIZE field:** If the SST79LF008 receives an invalid size field during a Firmware Memory Read or Write operation, the device will ignore the cycle and no operation will be attempted. The device will not generate any kind of response in this situation. The SST79LF008 will only respond to MSIZE values listed in the Table 7-11.

#### TABLE 7-11: Valid MSIZE Field for Firmware Memory Cycle

| Bits | Direction | Size of transfer |
|------|-----------|------------------|
| 0000 | R/W       | 1 Byte           |
| 0001 | R/W       | 2 Byte           |
| 0010 | R/W       | 4 Byte           |
| 0100 | R         | 16 Byte          |
| 0111 | R         | 128 Byte         |

T7-11.0 1320



Once valid START, IDSEL, and MSIZE are received, the SST79LF008 will always complete the bus cycle. However, if the device is busy performing a flash Erase or Program operation, no new internal memory write will be executed. As long as the states of LAD[3:0] and LFRAME# are known, the response of the SST79LF008 to signals received during the cycle is predictable.

**Non-boundary-aligned address:** The SST79LF008 accepts Multi-Byte transfers for both Read and Write operations. The device address space is thus divided into pages of uniform size 2, 4, 16, or 128 Byte wide, according to the MSIZE value. The host issues only one address in the MADDR field of the Firmware Memory Cycle but multiple bytes are read from, or written to, the device. For this reason the MADDR address should be page "boundary aligned".

Boundary aligned means that for a 2 Byte transfer the address should be aligned to a Word boundary ( $A_0 = 0$ ), for a 4 Byte transfer the address should be aligned to a Double Word boundary ( $A_0 = 0$ ,  $A_1 = 0$ ), etc. If the address supplied by the host is not page "boundary aligned", the SST79LF008 will force a boundary alignment, starting the Multi-Byte Read or Write operation from the lower Byte of the addressed page.

## 7.4.2 Response to Invalid Fields for LPC Memory Cycle

**ID mismatch**: The SST79LF008 interprets address bits [A<sub>24</sub>:A<sub>23</sub>, A<sub>21</sub>:A<sub>20</sub>] as ID information and compares them with the complement of ID value specified by the SST79LF008 input ID pin. If there is a mismatch, the device will ignore the cycle. See Multiple Device Selection, Section 7.5, for details.

Address out of range: The address sequence is 8 fields long (32 bits). The address bits  $[A_{24}:A_{23}, A_{21}:A_{20}]$  for the SST79LF008 are used to select the device with proper IDs. The most significant address bits  $[A_{31}:A_{25}]$  must be "1's" for LPC memory cycle to be completed. Address  $A_{22}$  has the special function of directing reads and writes to the flash core  $(A_{22} = 1)$  or to the register space  $(A_{22} = 0)$ .

For the boot device (with LPC protocol ID = 0), the SST79LF008 also decodes the physical addresses of the top 128 KByte blocks at two system memory ranges:

- FFFF FFFFH to FFFE 0000H—top of 4 GByte address space
- 000F FFFFH to 000E 0000H—top of legacy 1 MByte address space

Once valid START, CYCTYPE + DIR, and address range, including ID bits, are received, the SST79LF008 will always complete the bus cycle. However, if the device is busy per-

forming a flash Erase or Program operation, no new internal memory write will be executed. As long as the states of LAD[3:0] and LFRAME# are known, the response of the SST79LF008 to signals received during the LPC cycle is predictable.

## 7.5 Multiple Device Selection

Multiple LPC firmware memory devices may be strapped to increase memory densities in a system. BIOS support, bus loading, or the attaching bridge may limit the number of connected devices. The boot device must respond to LPC protocol with ID of 0 (0000b); subsequent devices use incremental numbering. Equal density must be used with multiple devices.

With one ID input pin SST79LF008 can have two different LPC protocol ID values. Respectively, SST79LF008 flash memory array will be mapped into two different address ranges in the 4GByte system memory space depending on ID pin logic level. When V<sub>IL</sub> level is applied to ID input pin, the valid LPC protocol ID is 0 (0000b). When V<sub>IH</sub> level is applied to ID input pin, the valid LPC protocol ID is 1 (0001b).

## 7.5.1 Multiple Device Selection for Firmware Memory Cycle

For Firmware Memory Read/Write cycles, LPC protocol ID information is included into IDSEL field of every cycle. The ID value specified by SST79LF008 ID input pin (0000b or 0001b) must match the value in IDSEL field. If there is a mismatch the SST79LF008 will ignore the respective LPC Firmware Memory cycle.

## 7.5.2 Multiple Device Selection for LPC Memory Cycle

For LPC Memory Read/Write cycles, LPC protocol ID information is included in the address bits of every cycle. The address bits  $[A_{24}:A_{23}, A_{21}:A_{20}]$  are used to select the device with proper IDs. The ID bits in the address field must match the inverse of the ID value specified by SST79LF008 ID input pin (i.e., address bits should be 1111b when VIL level is applied to ID input pin or 1110b when VIH level is applied to ID input pin). If there is a mismatch the SST79LF008 will ignore the respective LPC Memory cycle.



## 7.6 LPC Memory Mapped Registers.

The LPC memory mapped registers can be accessed by LPC Firmware Memory cycles as well as by LPC Memory cycles with address bit  $A_{22} = 0$ . Four types of registers are implemented in SST79LF008: Block Locking registers, JEDEC ID Registers, Multi-byte Read/Write Configuration Registers, and Unique ID Registers. These registers appear at their respective addresses in the 4GByte system memory address space as specified in Table 7-12 for the boot device. They will appear elsewhere if SST79LF008 is not the boot device according to Multiple Device Selection

mechanism described in Section 7.5. Read access to unused register locations will return 00H. Write access to these locations has no effect. Attempts to read or write any register during internal Program/Erase operation are completed normally.

#### 7.6.1 Flash Memory Block Locking Registers

SST79LF008 provides software controlled lock protection through a set of Block Locking registers. These registers are read/write accessible via standard memory locations specified in Table 7-12.

|              |      | Protected Memory | Memory Map Register     | Reset              |        |  |
|--------------|------|------------------|-------------------------|--------------------|--------|--|
| Register     | Size | Address Range    | Address for Boot Device | Value <sup>1</sup> | Access |  |
| T_BLOCK_LK   | 16K  | 0FFFFFH-0FC000H  | FFBFC002H               | 01H                | R/W    |  |
| T_MINUS01_LK | 8K   | 0FBFFFH-0FA000H  | FFBFA002H               | 01H                | R/W    |  |
| T_MINUS02_LK | 8K   | 0F9FFFH-0F8000H  | FFBF8002H               | 01H                | R/W    |  |
| T_MINUS03_LK | 32K  | 0F7FFFH-0F0000H  | FFBF0002H               | 01H                | R/W    |  |
| T_MINUS04_LK | 64K  | 0EFFFFH-0E0000H  | FFBE0002H               | 01H                | R/W    |  |
| T_MINUS05_LK | 64K  | 0DFFFFH-0D0000H  | FFBD0002H               | 01H                | R/W    |  |
| T_MINUS06_LK | 64K  | 0CFFFFH-0C0000H  | FFBC0002H               | 01H                | R/W    |  |
| T_MINUS07_LK | 64K  | 0BFFFFH-0B0000H  | FFBB0002H               | 01H                | R/W    |  |
| T_MINUS08_LK | 64K  | 0AFFFFH-0A0000H  | FFBA0002H               | 01H                | R/W    |  |
| T_MINUS09_LK | 64K  | 09FFFFH-090000H  | FFB90002H               | 01H                | R/W    |  |
| T_MINUS10_LK | 64K  | 08FFFFH-080000H  | FFB80002H               | 01H                | R/W    |  |
| T_MINUS11_LK | 64K  | 07FFFFH-070000H  | FFB70002H               | 01H                | R/W    |  |
| T_MINUS12_LK | 64K  | 06FFFFH-060000H  | FFB60002H               | 01H                | R/W    |  |
| T_MINUS13_LK | 64K  | 05FFFFH-050000H  | FFB50002H               | 01H                | R/W    |  |
| T_MINUS14_LK | 64K  | 04FFFFH-040000H  | FFB40002H               | 01H                | R/W    |  |
| T_MINUS15_LK | 64K  | 03FFFFH-030000H  | FFB30002H               | 01H                | R/W    |  |
| T_MINUS16_LK | 64K  | 02FFFFH-020000H  | FFB20002H               | 01H                | R/W    |  |
| T_MINUS17_LK | 64K  | 01FFFFH-010000H  | FFB10002H               | 01H                | R/W    |  |
| T_MINUS18_LK | 64K  | 00FFFFH-000000H  | FFB00002H               | 01H                | R/W    |  |

#### TABLE 7-12: Block Locking Registers

T7-12.0 1320

1. All block locking registers returned to their reset values specified above after any one of the following reset events: Power-On Reset, External Reset, Watchdog Timer Reset, Brown-Out Reset, aLPC Soft Reset, or external LPC Interface Reset (see also Section 5.2.)



In case of multi-byte register reads with Firmware Memory cycle, the device will return register data for the addressed register until the command finishes or is aborted.

Bit definitions for block locking registers are specified in Table 7-13.

| Reserved Bit<br>[7:3] | Read-Lock Bit<br>[2] <sup>1</sup> | Lock-Down Bit<br>[1] <sup>2</sup> | Write-Lock Bit<br>[0] <sup>3</sup> | Lock Status                                           |
|-----------------------|-----------------------------------|-----------------------------------|------------------------------------|-------------------------------------------------------|
| 00000                 | 0                                 | 0                                 | 0                                  | Full Access                                           |
| 00000                 | 0                                 | 0                                 | 1                                  | Write Locked (Default State after reset)              |
| 00000                 | 0                                 | 1                                 | 0                                  | Locked Open (Full Access Locked Down)                 |
| 00000                 | 0                                 | 1                                 | 1                                  | Write Locked Down                                     |
| 00000                 | 1                                 | 0                                 | 0                                  | Block Read Locked (Registers alterable)               |
| 00000                 | 1                                 | 0                                 | 1                                  | Block Read & Write Lock (Registers not alterable)     |
| 00000                 | 1                                 | 1                                 | 0                                  | Block Read Locked Down (Register not alterable)       |
| 00000                 | 1                                 | 1                                 | 1                                  | Block Read & Write lock Down (Register not alterable) |

#### TABLE 7-13: Block Locking Register Bits

T7-13.0 1320

1. <u>Read Lock</u>: The Read-Lock bit, bit 2, controls the read access. The default read status of all blocks after reset is read-unlocked. When a block's read lock bit is set, data cannot be read from that block. An attempted read from a read-locked block will result in the data 00h. The read lock status can be unlocked by clearing the read lock bit, provided that the block is not locked down. The current read lock status of a particular block can be determined by reading the corresponding read-lock bit.

- 2. Lock Down. The Lock-Down bit, bit 1, controls the Block Locking register. The default Lock Down status of all blocks after reset is not locked down. Once the Lock-Down bit is set, any future attempted changes to that Block Locking register will be ignored. The Lock-Down bit is only cleared upon a device reset. Current Lock Down status of a particular block can be determined by reading the corresponding Lock-Down bit. Once a block's Lock-Down bit is set, the Read- and Write-Lock bits for that block can no longer be modified, and the block is locked down in its current state of read/write accessibility.
- 3. <u>Write-Lock</u>: The Write-Lock bit, bit 0, controls the Program/Erase lock state. The default Write status of all blocks after reset is write locked. When bit 0 of the Block Locking register is set, Program and Erase operations for the corresponding block is prevented. Clearing the Write-Lock bit will unprotect the block. The Write-Lock bit must be cleared prior to starting a Program or Erase operation because it is sampled at the beginning of the operation.
- **Note:** The registers (T\_BLOCK\_LK, T\_MINUS01\_LK, T\_MINUS02\_LK, and T\_MINUS03\_LK) protect memory areas within one 64 KByte flash memory Block15 (see Figure 4-1). Therefore, when any of these memory areas are write-protected the Block Erase command for Block15 is not accepted.

#### 7.6.2 JEDEC ID Registers

The JEDEC ID registers are read-only registers and are accessible via memory locations specified in Table 7-14. In case of multi-byte register reads with Firmware Memory cycle, the device will return register data for the addressed register until the command finishes or is aborted.

|                           | -                                      |       |        |
|---------------------------|----------------------------------------|-------|--------|
| Register                  | Register<br>Address for<br>Boot Device | Value | Access |
| Manufacturer ID           | FFBC0000H                              | BFH   | R      |
| Device ID<br>(SST79LF008) | FFBC0001H                              | F0H   | R      |

| TABLE | 7-14: | JEDEC ID | Registers |
|-------|-------|----------|-----------|
|-------|-------|----------|-----------|

## 7.6.3 Multi-byte Read/Write Configuration Registers

The multi-byte read/write configuration (MBR) registers are four 8-bit read-only registers located at addresses specified in Table 7-15. These registers are accessible using Firmware Memory Read cycle only. The device will return unused register space data (00H) if these registers are addressed via LPC memory read cycles. These registers contain information about multi-byte read and write access sizes that will be accepted for Firmware Memory multi-byte commands. In case of multi-byte register reads, device will return register data for addressed register until the command finishes or is aborted.

T7-14.0 1320



| Register           | Register<br>Address for<br>Boot Device | Value      | Access | Description                               |
|--------------------|----------------------------------------|------------|--------|-------------------------------------------|
| MULTI_BYTE_READ_L  | FFBC0005H                              | 0100 1011b | R      | Device supports 1,2,4, 16, 128 byte reads |
| MULTI_BYTE_READ_H  | FFBC0006H                              | 0000 0000b | R      | Future Expansion for read                 |
| MULTI_BYTE_WRITE_L | FFBC0007H                              | 0000 0011b | R      | Device supports 2,4 byte write            |
| MULTI_BYTE_WRITE_H | FFBC0008H                              | 0000 0000b | R      | Future Expansion for write                |

TABLE 7-15: Multi-byte Read/Write Configuration registers

T7-15.0 1320

#### 7.6.4 Unique ID Registers

In addition to Read Unique ID command described in Section 7.3, the SST79LF008 allows the LPC Host to read Unique ID Information and its Write Lock/Unlock status via LPC memory mapped register space at addresses defined in Table 7-16. In case of multi-byte register reads with Firmware Memory cycle, for the all UID\_BYTE registers, the device will return page aligned sequential register data with wrap-around until the command finishes or is aborted. Multi-byte read of UID\_WRITE\_LOCK register will return register data for the addressed register until the command finishes or is aborted.

All Unique ID registers are read-only registers. The Unique ID Program and Lockout commands shown in Table 7-16 can be used to write (program) and lock Unique ID.

| Register       | Register Address | Value      | Access | Description        |
|----------------|------------------|------------|--------|--------------------|
| UID_WRITE_LOCK | FFBC017FH        | 0000 0000b | R      | Write Unlocked     |
|                |                  | 0000 0001b |        | Write Locked       |
| UID_BYTE_0     | FFBC0180H        |            | R      | Factory Programmed |
| UID_BYTE_1     | FFBC0181H        |            | R      | Factory Programmed |
| UID_BYTE_2     | FFBC0182H        |            | R      | Factory Programmed |
| UID_BYTE_3     | FFBC0183H        |            | R      | Factory Programmed |
| UID_BYTE_4     | FFBC0184H        |            | R      | Factory Programmed |
| UID_BYTE_5     | FFBC0185H        |            | R      | Factory Programmed |
| UID_BYTE_6     | FFBC0186H        |            | R      | Factory Programmed |
| UID_BYTE_7     | FFBC0187H        |            | R      | Factory Programmed |
| UID_BYTE_8     | FFBC0188H        |            | R      | User Programmed    |
| UID_BYTE_9     | FFBC0189H        |            | R      | User Programmed    |
|                |                  |            |        |                    |
| UID_BYTE_30    | FFBC019EH        |            | R      | User Programmed    |
| UID_BYTE_31    | FFBC019FH        |            | R      | User Programmed    |

#### TABLE 7-16: Unique ID Registers

T7-16.0 1320

## 7.7 PCI CLOCK RUN CONTROL SUPPORT

The SST79LF008 supports the CLKRUN# input/open drain output signal according to the PCI Mobile Design Guide Rev 1.0 specification. This signal is used by the system to indicate the LPC clock status. When CLKRUN# is "high", the LPC clock is, or is about to be, stopped. When CLKRUN# is "low", the LPC clock is running.

The CLKRUN# is used by SST79LF008 to request restarting the stopped clock in order to report the Serialized IRQs status changes. If any module within the SST79LF008 asserts or de-asserts serialized interrupt to the system and the CLKRUN# input is "high", the SST79LF008 can request the restoration of the clock by the assertion of the CLKRUN# signal low. The SST79LF008 drives CLKRUN#



low until it detects two rising edges of the restarted LPC clock. After the second clock edge, the SST79LF008 disables its CLKRUN# open drain driver.

The SST79LF008 would not assert CLKRUN# if it is already driven low by the central resource or any other device on the bus. Also, the SST79LF008 would not assert CLKRUN# unless the line has been de-asserted for two successive clocks; for example, before the clock was stopped. Additionally, CLKRUN# is asserted if 8051 core tries to access any device 0, 1, or 3 configuration register and the device configuration register index 30H value is 00H (inactive). See Table 23-1 for Configuration Registers Map.

Refer to the PCI Mobile Design Guide Rev 1.0 for a detailed description of the CLKRUN# function.

## 7.8 LPC Power Down Protocol Support

The SST79LF008 supports the LPCPD# input signal. This signal is asserted by the system prior to going to low-power state. After LPCPD# is activated (with at least 30 microseconds delay) the LPC clock is stopped low, and the other host LPC I/F output signals being tri-stated or driven low.

Upon recognizing that LPCPD# is asserted, there will be no further transactions on the LPC interface. While LPCPD# is asserted, the SST79LF008 continues to drive IRQ1 and IRQ12 frames. After LPCPD# is de-asserted, the LPC interface may be reset depending on the characteristics of the system reset signal connected to LRESET# pin. The SST79LF008, however, resets internal LPC protocol state machine on exit from LPC low power state without LRESET# going active.

The SST79LF008 asynchronously recognizes LPCPD# state changes from active to inactive and vice versa. (Note that LPCPD# signal, may not meet setup times to LCLK, however, it can be sampled with LCLK, since the clock is running for at least 30 microseconds after LPCPD# goes low, and for more than 30 microseconds prior to LPCPD# going high.)

The state of the LPCPD# signal can be directly read via LPCMON register (see Section 23.1); LPCPD# signal transition generates interrupt request to 8051 core via WSRCG register (see Section 8.3).

Refer to the LPC Interface Specification, Rev 1.1 for a detailed description of the LPCPD# function.



## 8.0 INTERRUPTS AND WAKEUPS

## 8.1 SST79LF008 Interrupts

SST79LF008 has eleven interrupt sources under a fourlevel priority scheme. Table 8-1 and Figures 8-1, 8-2, 8-3, 8-4, and 8-5 summarize the supported interrupt structure. Interrupt 0 (INT0) is dedicated for matrix keyboard event. Interrupt 1 (INT1) combines interrupt source registers A and B. Interrupt 2 (INT2) combines wakeup event source registers A and B. Interrupt 3 (INT3) combines wakeup event source registers C,D, and E. Interrupt 4 (INT4) combines wakeup event source registers F,G, H and I. Interrupt 5 (INT5) combines wakeup event source registers J, K, L, M, N, O and P. For details on INT0-INT5 interrupt sources see Section 8.3.

Timer 0 and Timer 1 (TF0, TF1) as well as serial interface interrupt (SPI) are dedicated interrupts. Timer 2 interrupt combines timer 2 overflow and external flag interrupts (TF2 or EXF2). Serial port UART interrupt combines transmit and receive interrupts (TI or RI). For details on Timer 0-2, UART and SPI interrupt sources see Sections 10.0, 11.0, 12.0.

| Interrupt      | Description                 | Priority<br>within<br>level <sup>1</sup> | Interrupt request<br>flag      | ENABLE | Priority level control | Interrupt<br>vector<br>address | Wakeup<br>Idle/Power<br>Down |
|----------------|-----------------------------|------------------------------------------|--------------------------------|--------|------------------------|--------------------------------|------------------------------|
| INT0           | Keyboard                    | 1                                        | TCON.1                         | IE.0   | IP.0,IPH.0             | 03H                            | Yes/Yes                      |
| TF0            | Timer 0 interrupt           | 2                                        | TCON.5                         | IE.1   | IP.1,IPH.1             | 0BH                            | Yes/No                       |
| INT1           | Interrupt source A<br>and B | 3                                        | TCON.3                         | IE.2   | IP.2,IPH.2             | 13H                            | Yes/No                       |
| TF1            | Timer 1 interrupt           | 4                                        | TCON.7                         | IE.3   | IP.3,IPH.3             | 1BH                            | Yes/No                       |
| TI or RI       | UART                        | 5                                        | SCON.0(RI),<br>SCON.1(TI)      | IE.4   | IP.4,IPH.4             | 23H                            | Yes/No                       |
| TF2 or<br>EXF2 | Timer 2 interrupt           | 6                                        | T2CON.7(TF2),<br>T2CON.6(EXF2) | IE.5   | IP.5,IPH.5             | 2BH                            | Yes/No                       |
| INT2           | External interrupt 2        | 7                                        | EXIF.0                         | IEA.0  | IPA.0,IPAH.0           | 33H                            | Yes/Yes                      |
| INT3           | External interrupt 3        | 8                                        | EXIF.1                         | IEA.1  | IPA.1,IPAH.1           | 3BH                            | Yes/Yes                      |
| INT4           | External interrupt 4        | 9                                        | EXIF.2                         | IEA.2  | IPA.2,IPAH.2           | 43H                            | Yes/Yes                      |
| INT5           | External interrupt 5        | 10                                       | EXIF.3                         | IEA.3  | IPA.3,IPAH.3           | 4BH                            | Yes/Yes                      |
| SPI            | SPI interrupt               | 11                                       | SPSR.7                         | SPCR.7 | IP.7,IPH.7             | 53H                            | Yes/Yes                      |

#### TABLE 8-1: SST79LF008 Interrupt Sources

T8-1.1320

1. Priority within level order -- 1(INTO)=highest/11(SPI)=lowest--is used to resolve simultaneous interrupt requests of the same level.

## Mobile Platform Controller 8 Mbit LPC Firmware Flash SST79LF008









FIGURE 8-2: SST79LF008 Interrupt Structure (int3)





FIGURE 8-3: SST79LF008 Interrupt Structure (int4)





FIGURE 8-4: 55179LF008 Interrupt Structure (Int





FIGURE 8-5: SST79LF008 Interrupt Structure (int5, pd mode wakeup, 8051 interrupt)



## 8.2 SST79LF008 Wakeups

SST79LF008 wake-up sources include LPC cycle start, LPCPD# signal transition, SPI slave clock change, SMBus start condition, PS2 clock falling edge, Matrix keyboard scanner input falling edge, Hibernation timer, FAN tachometers, and programmable GPIOs.

All GPIO wake up and interrupt sources are edge sensitive. Active edge for each wake up and interrupt is software specified via the Active Edge Selection registers. Unless Mobile Platform Controller 8 Mbit LPC Firmware Flash SST79LF008

explicitly stated otherwise, the GPIO wake up and interrupt requests are not asserted if the alternate function is selected for the respective pin.

For detailed information on Interrupt and Wake up Source registers and their associated Mask registers, as well as Active Edge Selection registers, refer to Section 8.3. Refer to Section 9.1 for Alternate Function Select registers. Changes in GPIO configuration, function, or edge selection may generate spurious interrupt requests, which are addressed by software.

## 8.3 INTERRUPT CONTROL REGISTERS

#### 8.3.1 External Interrupt Flag Register (EXIF)

| Location |       | 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     |
|----------|-------|---|---|---|---|-------|-------|-------|-------|
|          | Read  |   |   |   |   | INT5F | INT4F | INT3F | INT2F |
| ABH      | Write | - | - | - | - | -     | -     | -     | -     |
|          | Reset | Х | Х | Х | Х | 0     | 0     | 0     | 0     |

#### Symbol

| х         |
|-----------|
| INT[5:2]F |

## Function

Not implemented Not defined Interrupt 5-2 flag 1: Interrupt pending 0: No Interrupt

#### 8.3.2 Interrupt Enable Register (IE)

| Location |       | 7  | 6 | 5   | 4  | 3   | 2   | 1   | 0   |
|----------|-------|----|---|-----|----|-----|-----|-----|-----|
|          | Read  | EA |   | ET2 | ES | ET1 | EX1 | ET0 | EX0 |
| A8H      | Write |    | - |     |    |     |     |     |     |
|          | Reset | 0  | Х | 0   | 0  | 0   | 0   | 0   | 0   |

| Symbol | Function                 |
|--------|--------------------------|
| -      | Not implemented          |
| Х      | Not defined              |
| EA     | Enable Global Interrupt  |
| ET2    | Enable Timer 2 Interrupt |
| ES     | Enable UART Interrupt    |
| ET1    | Enable Timer 1 Interrupt |
| EX1    | Enable Interrupt 1       |
| ET0    | Enable Timer 0 Interrupt |
| EX0    | Enable Interrupt 0       |
|        | 1: Enable Interrupt      |
|        | 0: Disable Interrupt     |



### 8.3.3 Interrupt Enable Register A (IEA)

| Location |             | 7 | 6                | 5                      | 4 | 3   | 2   | 1   | 0   |
|----------|-------------|---|------------------|------------------------|---|-----|-----|-----|-----|
|          | Read        |   |                  |                        |   | EX5 | EX4 | EX3 | EX2 |
| E8H      | Write       | - | -                | -                      | - |     |     |     |     |
|          | Reset       | Х | Х                | Х                      | Х | 0   | 0   | 0   | 0   |
|          | Symbol<br>- |   | Functi<br>Not im | <b>on</b><br>olemented |   |     |     |     |     |

X EX[5:2] Not implemented Not defined

Enable Interrupt 5-2 1: Enable Interrupt

0: Disable Interrupt

### 8.3.4 Interrupt Priority Register (IP)

| Location |       | 7    | 6 | 5   | 4  | 3   | 2   | 1   | 0   |
|----------|-------|------|---|-----|----|-----|-----|-----|-----|
|          | Read  | PSPI |   | PT2 | PS | PT1 | PX1 | PT0 | PX0 |
| B8H      | Write |      | - |     |    |     |     |     |     |
|          | Reset | 0    | Х | 0   | 0  | 0   | 0   | 0   | 0   |

| Symbol | Function                       |
|--------|--------------------------------|
| -      | Not implemented                |
| Х      | Not defined                    |
| PSPI   | SPI Interrupt Priority Bit     |
| PT2    | Timer 2 Interrupt Priority Bit |
| PS     | UART Interrupt Priority Bit    |
| PT1    | Timer 1 Interrupt Priority Bit |
| PX1    | Interrupt 1 Priority Bit       |
| PT0    | Timer 0 Interrupt Priority Bit |
| PX0    | Interrupt 0 Priority Bit       |
|        |                                |

#### 8.3.5 Interrupt Priority High (IPH)

| Location |       | 7     | 6 | 5    | 4   | 3    | 2    | 1    | 0    |
|----------|-------|-------|---|------|-----|------|------|------|------|
|          | Read  | PSPIH |   | PT2H | PSH | PT1H | PX1H | PT0H | PX0H |
| B7H      | Write |       | - |      |     |      |      |      |      |
|          | Reset | 0     | Х | 0    | 0   | 0    | 0    | 0    | 0    |

| <br>   |                                                                                            |
|--------|--------------------------------------------------------------------------------------------|
| Symbol | Function                                                                                   |
| -      | Not implemented                                                                            |
| Х      | Not defined                                                                                |
| PSPIH  | SPI Interrupt Priority Bit High, with PSPI provides 4 Level Priority (11b = highest)       |
| PT2H   | Timer 2 Interrupt Priority Bit High, with PT2 provides 4 Level Priority (11b =<br>highest) |
| PSH    | UART Interrupt Priority Bit High, with PS provides 4 Level Priority (11b = highest)        |
| PT1H   | Timer 1 Interrupt Priority Bit High, with PT1 provides 4 Level Priority (11b =<br>highest) |
| PX1H   | Interrupt 1 Priority Bit High, with PX1 provides 4 Level Priority (11b = highest)          |
| PT0H   | Timer 0 Interrupt Priority Bit High, with PT0 provides 4 Level Priority (11b =<br>highest) |
| PX0H   | Interrupt 0 Priority Bit High, with PX0 provides 4 Level Priority (11b = highest)          |



#### 8.3.6 Interrupt Priority Register A (IPA)

| Location |       | 7 | 6 | 5 | 4 | 3   | 2   | 1   | 0   |
|----------|-------|---|---|---|---|-----|-----|-----|-----|
|          | Read  |   |   |   |   | PX5 | PX4 | PX3 | PX2 |
| F8H      | Write | - | - | - | - |     |     |     |     |
|          | Reset | Х | Х | Х | Х | 0   | 0   | 0   | 0   |

Symbol -X Function Not implemented

Not defined

PX[5:2] Interrupt 5-2 Priority bits

#### 8.3.7 Interrupt Priority High Register A (IPAH)

| Location |       | 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|----------|-------|---|---|---|---|------|------|------|------|
|          | Read  |   |   |   |   | PX5H | PX4H | РХЗН | PX2H |
| F7H      | Write | - | - | - | - |      |      |      |      |
|          | Reset | Х | Х | Х | Х | 0    | 0    | 0    | 0    |

Symbol

PX[5:2]H

Х

## Function

Not implemented

Not defined

External Interrupt 5-2 Priority Bit High, with PX[5:2] provide 4 Level Priority (11b = highest)

#### 8.3.8 Interrupt Source Register A (INTSRCA)

| Location |                   | 7                                                                                                                                      | 6                                                                                                                                                                           | 5                             | 4                             | 3             | 2              | 1            | 0               |  |  |
|----------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-------------------------------|---------------|----------------|--------------|-----------------|--|--|
| -        | Read              | KCOBE                                                                                                                                  | KCIBF                                                                                                                                                                       | SM1INT                        | SM0INT                        |               | ADCINT         | CLKINT       | WDT             |  |  |
| 7F00H    | Write             | -                                                                                                                                      | -                                                                                                                                                                           | -                             | -                             | -             | -              |              | -               |  |  |
|          | Reset             | 1                                                                                                                                      | 0                                                                                                                                                                           | 0                             | 0                             | Х             | 0              | 0            | 0               |  |  |
|          | Symbol Function   |                                                                                                                                        |                                                                                                                                                                             |                               |                               |               |                |              |                 |  |  |
|          | - Not implemented |                                                                                                                                        |                                                                                                                                                                             |                               |                               |               |                |              |                 |  |  |
|          | Х                 | Not defined                                                                                                                            |                                                                                                                                                                             |                               |                               |               |                |              |                 |  |  |
|          | KCOBE             | Keyboard controller OBE (Output Buffer Empty) interrupt flag. Set when OBF bit in KBCSTS register is '0', cleared when OBF bit is '1'. |                                                                                                                                                                             |                               |                               |               |                |              |                 |  |  |
|          | KCIBF             | Keyboard controller IBF (Input Buffer Full) interrupt flag. Set when IBF bit in KBCSTS register is '1', cleared when IBF bit is '0'.   |                                                                                                                                                                             |                               |                               |               |                |              |                 |  |  |
|          | SM1INT            |                                                                                                                                        |                                                                                                                                                                             | channel 1 d<br>when INT b     | or 2 interrupt<br>bit is '0'. | flag. Set wh  | ien INT bit in | SMCR1 reg    | gister is '1',  |  |  |
|          | SMOINT            |                                                                                                                                        |                                                                                                                                                                             | channel 0 i<br>NT bit is '0'. | nterrupt flag.                | Set when I    | NT bit in SM   | CR0 register | is '1', cleared |  |  |
|          | ADCINT            |                                                                                                                                        |                                                                                                                                                                             | nversion cor<br>ared when A   |                               | rupt flag. Se | et when ADF    | bit in ADCS  | SR register is  |  |  |
|          | CLKINT            |                                                                                                                                        | Clock source change interrupt flag. Set when PLLOK bit changes from '0' to '1', or on any change of ECLOK bit. Write '0' to clear. Writing '1' to this bit will be ignored. |                               |                               |               |                |              |                 |  |  |
|          | WDT               |                                                                                                                                        |                                                                                                                                                                             | log timer un<br>ed or disable |                               | Set when W    | /DT underflo   | ws, cleared  | when WDT is     |  |  |



### 8.3.9 Interrupt Source A Mask Register (INTSRCAMSK)

| Location                                     |         | 7     | 6                                                                  | 5               | 4      | 3      | 2       | 1       | 0       |  |  |  |
|----------------------------------------------|---------|-------|--------------------------------------------------------------------|-----------------|--------|--------|---------|---------|---------|--|--|--|
|                                              | Read    | KCOBE | KCIBF                                                              | SM1INT          | SM0INT |        | ADCINT  | CLKINT  | WDT     |  |  |  |
| 7F01H                                        | Write   | MSK   | MSK                                                                | MSK             | MSK    | -      | MSK     | MSK     | MSK     |  |  |  |
|                                              | Reset   | 0     | 0                                                                  | 0               | 0      | Х      | 0       | 0       | 0       |  |  |  |
| Symbol Function                              |         |       |                                                                    |                 |        |        |         |         |         |  |  |  |
|                                              | -       |       | Not imp                                                            | Not implemented |        |        |         |         |         |  |  |  |
| Х                                            |         |       | Not defined                                                        |                 |        |        |         |         |         |  |  |  |
|                                              | KCOBEMS | K,,   | Interrupt Source Mask                                              |                 |        |        |         |         |         |  |  |  |
|                                              | WDTMSK  |       | 1: Enable Interrupt from the respective source in INTSRCA register |                 |        |        |         |         |         |  |  |  |
|                                              |         |       | 0: Mask Interrupt source                                           |                 |        |        |         |         |         |  |  |  |
| 8.3.10 Interrupt Source Register B (INTSRCB) |         |       |                                                                    |                 |        |        |         |         |         |  |  |  |
| Location                                     |         | 7     | 6                                                                  | 5               | 4      | 3      | 2       | 1       | 0       |  |  |  |
|                                              | Read    | ECOBE | ECIBF                                                              | MBXINT          | ECOBE1 | ECIBF1 | PS22INT | PS21INT | PS20INT |  |  |  |
| 7F02H                                        | Write   | -     | -                                                                  | -               | -      | -      | -       | -       | -       |  |  |  |

| cation |       | 1     | 6     | 5      | 4      | 3      | 2       | 1       | 0      |
|--------|-------|-------|-------|--------|--------|--------|---------|---------|--------|
|        | Read  | ECOBE | ECIBF | MBXINT | ECOBE1 | ECIBF1 | PS22INT | PS21INT | PS20II |
| F02H   | Write | -     | -     | -      | -      | -      | -       | -       | -      |
|        | Reset | 1     | 0     | 0      | 1      | 0      | 0       | 0       | 0      |
|        |       |       |       |        |        |        |         |         |        |

| Symbol  | Function                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -       | Not implemented                                                                                                                                                                                                                                                                                                                                                                                                             |
| ECOBE   | ACPI ECI channel 0 Output Buffer Empty interrupt flag. Set when OBF bit in<br>ECISTS register is '0', cleared when OBF bit is '1'.                                                                                                                                                                                                                                                                                          |
| ECIBF   | ACPI ECI channel 0 Input Buffer Full interrupt flag. Set when IBF bit in ECISTS register is '1', cleared when IBF bit is '0'.                                                                                                                                                                                                                                                                                               |
| MBXINT  | Mailbox interface System-to-8051 interrupt. Set when the system writes to Mailbox register 0, cleared when 8051 reads Mailbox register 0.                                                                                                                                                                                                                                                                                   |
| ECOBE1  | ACPI ECI channel 1 Output Buffer Empty interrupt flag. Set when OBF bit in<br>ECISTS1 register is '0', cleared when OBF bit is '1'.                                                                                                                                                                                                                                                                                         |
| ECIBF1  | ACPI ECI channel 1 Input Buffer Full interrupt flag. Set when IBF bit in ECISTS1 register is '1', cleared when IBF bit is '0'.                                                                                                                                                                                                                                                                                              |
| PS22INT | PS2 channel 2 interrupt<br>If PS/2 h/w state machine is enabled, set by '0' to '1' transition of any of the<br>following bits in PS2STS2 register: PS2STSn_RDATA_RDY,<br>PS2STSn_XMIT_IDLE, PS2STSn_R_TIMEOUT or PS2STSn_T_TIMEOUT.<br>If PS/2 h/w state machine is disabled, set by falling edge on PSCLK2 pin driven by<br>the peripheral.<br>Cleared by reading PS2STS2 register (in any mode of PS2 h/w state machine). |
| PS21INT | PS2 channel 1 interrupt<br>If PS/2 h/w state machine is enabled, set by '0' to '1' transition of any of the<br>following bits in PS2STS1 register: PS2STSn_RDATA_RDY,<br>PS2STSn_XMIT_IDLE, PS2STSn_R_TIMEOUT or PS2STSn_T_TIMEOUT.<br>If PS/2 h/w state machine is disabled, set by falling edge on PSCLK1 pin driven by<br>the peripheral.<br>Cleared by reading PS2STS1 register (in any mode of PS2 h/w state machine). |
| PS20INT | PS2 channel 0 interrupt<br>If PS/2 h/w state machine is enabled, set by '0' to '1' transition of any of the<br>following bits in PS2STS0 register: PS2STSn_RDATA_RDY,<br>PS2STSn_XMIT_IDLE, PS2STSn_R_TIMEOUT or PS2STSn_T_TIMEOUT.<br>If PS/2 h/w state machine is disabled Set by falling edge on PSCLK0 pin driven by<br>the peripheral.<br>Cleared by reading PS2STS0 register (in any mode of PS2 h/w state machine).  |



#### 8.3.11 Interrupt Source B Mask Register (INTSRCBMSK)

| Location |       | 7     | 6     | 5      | 4      | 3      | 2       | 1       | 0       |
|----------|-------|-------|-------|--------|--------|--------|---------|---------|---------|
|          | Read  | ECOBE | ECIBF | MBXINT | ECOBE1 | ECIBF1 | PS22INT | PS21INT | PS20INT |
| 7F03H    | Write | MSK   | MSK   | MSK    | MSK    | MSK    | MSK     | MSK     | MSK     |
|          | Reset | 0     | 0     | 0      | 0      | 0      | 0       | 0       | 0       |

Symbol ECOBEMSK, ..., PS20INTMSK Function

Interrupt Source Mask

1: Enable Interrupt from the respective source in INTSRCB register 0: Mask Interrupt source

#### 8.3.12 Wakeup Source A Register (WSRCA)

| Location |                                                                                                                                       | 7     | 6                   | 5                                                                                                                                                                                                             | 4       | 3      | 2                                                                   | 1      | 0   |  |  |  |
|----------|---------------------------------------------------------------------------------------------------------------------------------------|-------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------|---------------------------------------------------------------------|--------|-----|--|--|--|
|          | Read                                                                                                                                  | SMB0_ | PS2_SB2             | PS2_SB1                                                                                                                                                                                                       | PS2_SB0 | SPICLK |                                                                     | HIB_TO | LPC |  |  |  |
| 7F2AH    | Write                                                                                                                                 | DATA  |                     |                                                                                                                                                                                                               |         |        | -                                                                   | -      |     |  |  |  |
|          | Reset                                                                                                                                 | 0     | 0                   | 0                                                                                                                                                                                                             | 0       | 0      | Х                                                                   | 1      | 0   |  |  |  |
|          | Symbol                                                                                                                                |       | Functio             | Function                                                                                                                                                                                                      |         |        |                                                                     |        |     |  |  |  |
|          | -                                                                                                                                     |       | Not imp             | lemented                                                                                                                                                                                                      |         |        |                                                                     |        |     |  |  |  |
|          | Х                                                                                                                                     |       | Not def             | ned                                                                                                                                                                                                           |         |        |                                                                     |        |     |  |  |  |
|          | SMB0_DAT                                                                                                                              | A     | detecte             | SMBus channel 0 start condition detection flag. Set when start condition is detected Write '0' to clear. Writing '1' to this bit will be ignored.                                                             |         |        |                                                                     |        |     |  |  |  |
|          | PS2_SB2                                                                                                                               |       | PS2 cha<br>the peri | PS2 channel 2 start bit detection flag. Set by falling edge on PSCLK2 pin driven by the peripheral (in any mode of PS2 h/w state machine).<br>Write '0' to clear. Writing '1' to this bit will be ignored.    |         |        |                                                                     |        |     |  |  |  |
|          | PS2_SB1                                                                                                                               |       | the peri            | PS1 channel 1 start bit detection flag. Set by falling edge on PSCLK1 pin driven by the peripheral (in any mode of PS2 h/w state machine). Write '0' to clear. Writing '1' to this bit will be ignored.       |         |        |                                                                     |        |     |  |  |  |
|          | PS2_SB0                                                                                                                               |       | the peri            | PS2 channel 0 start bit detection flag. Set by falling edge on PSCLK0 pin driven by the peripheral (in any mode of PS2 h/w state machine). Write '0' to clear. Writing '1' to this bit will be ignored.       |         |        |                                                                     |        |     |  |  |  |
|          | SPICLK                                                                                                                                |       | Clock (S            | SPI clock edge detection flag (in SPI slave mode). Set when any transition of SPI<br>Clock (SCK) or SPI port Select (SS#) signal is detected.<br>Write '0' to clear. Writing '1' to this bit will be ignored. |         |        |                                                                     |        |     |  |  |  |
| -        |                                                                                                                                       |       |                     |                                                                                                                                                                                                               |         |        | timer time out flag. Set when Hibernation timer underflows, cleared |        |     |  |  |  |
|          | LPC LFRAME# falling edge detection flag. Set when falling edge is det<br>Write '0' to clear. Writing '1' to this bit will be ignored. |       |                     |                                                                                                                                                                                                               |         |        |                                                                     |        |     |  |  |  |



## 8.3.13 Wakeup Source A Wakeup Mask Register (WSRCAMSK)

| Location |                                           | 7                     | 6                                                                                                                                                                                                                                                                                                                | 5                                                                                                                                                                                                                                                                                                                       | 4               | 3              | 2 | 1       | 0       |  |  |  |  |
|----------|-------------------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------|---|---------|---------|--|--|--|--|
| 7F2BH    | Read<br>Write                             | SMB0_<br>DATA_MS<br>K | PS2_SB2<br>_MSK                                                                                                                                                                                                                                                                                                  | PS2_SB1<br>_MSK                                                                                                                                                                                                                                                                                                         | PS2_SB0<br>_MSK | SPICLK_<br>MSK | - | HIB_MSK | LPC_MSK |  |  |  |  |
|          | Reset                                     | 0                     | 0                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                       | 0               | 0              | Х | 0       | 0       |  |  |  |  |
|          | Symbol<br>-<br>X<br>SMB0_DAT<br>PS2_SB2_I | _ ,                   | Not imp<br>Not defi<br>Wakeup<br>1: Enab<br>0: Mask<br>Wakeup                                                                                                                                                                                                                                                    | Function<br>Not implemented<br>Not defined<br>Wakeup and Interrupt Source Mask<br>1: Enable Wakeup and Interrupt from the respective source in WSRCA register<br>0: Mask Wakeup and Interrupt source<br>Wakeup and Interrupt Source Mask<br>1: Enable Wakeup and Interrupt from the respective source in WSRCA register |                 |                |   |         |         |  |  |  |  |
|          | PS2_SB1_<br>PS2_SB0_                      |                       | 0: Mask Wakeup and Interrupt source<br>Wakeup and Interrupt Source Mask<br>1: Enable Wakeup and Interrupt from the respective source in WSRCA register<br>0: Mask Wakeup and Interrupt source<br>Wakeup and Interrupt Source Mask                                                                                |                                                                                                                                                                                                                                                                                                                         |                 |                |   |         |         |  |  |  |  |
|          | SPICLK_M                                  | SK                    | <ol> <li>Enable Wakeup and Interrupt from the respective source in WSRCA register</li> <li>Mask Wakeup and Interrupt source</li> <li>Wakeup and Interrupt Source Mask</li> <li>Enable Wakeup and Interrupt from the respective source in WSRCA register</li> <li>Mask Wakeup and Interrupt source</li> </ol>     |                                                                                                                                                                                                                                                                                                                         |                 |                |   |         |         |  |  |  |  |
|          | HIB_MSK                                   |                       | Wakeup and Interrupt Source Mask<br>1: Enable Wakeup and Interrupt from the respective source in WSRCA register<br>0: Mask Wakeup and Interrupt source<br>Wakeup and Interrupt Source Mask<br>1: Enable Wakeup and Interrupt from the respective source in WSRCA register<br>0: Mask Wakeup and Interrupt source |                                                                                                                                                                                                                                                                                                                         |                 |                |   |         |         |  |  |  |  |



## 8.3.14 Wakeup Source B Register (WSRCB)

| Location |                                                                                                                                                                 | 7    | 6                | 5                                                                                                                                                     | 4                                 | 3      | 2                               | 1            | 0       |  |  |  |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--------|---------------------------------|--------------|---------|--|--|--|
|          | Read                                                                                                                                                            | FAN2 | FAN1             |                                                                                                                                                       |                                   | LRESET | aLPCINT                         | SMB2_        | SMB1_   |  |  |  |
| 7F2CH    | Write                                                                                                                                                           | -    | -                | -                                                                                                                                                     | -                                 |        |                                 | DATA         | DATA    |  |  |  |
|          | Reset                                                                                                                                                           | 0    | 0                | Х                                                                                                                                                     | Х                                 | 0      | 0                               | 0            | 0       |  |  |  |
|          | Symbol                                                                                                                                                          |      | Function         |                                                                                                                                                       |                                   |        |                                 |              |         |  |  |  |
|          | -                                                                                                                                                               |      | Not implemented  |                                                                                                                                                       |                                   |        |                                 |              |         |  |  |  |
|          | Х                                                                                                                                                               |      | Not def          | ined                                                                                                                                                  |                                   |        |                                 |              |         |  |  |  |
|          | FAN[2:1] FAN Tachometer [2:1] threshold detection flag. Set when FAN tachor exceeds the threshold, cleared when counter is reloaded with value threshold.       |      |                  |                                                                                                                                                       |                                   |        |                                 |              |         |  |  |  |
|          | LRESET                                                                                                                                                          |      |                  |                                                                                                                                                       | ng edge dete<br>riting '1' to thi |        | et when falling<br>gnored.      | g edge is de | tected. |  |  |  |
|          | aLPCINT                                                                                                                                                         |      |                  | ce is receive                                                                                                                                         |                                   |        | flag. Set whe<br>0' to clear. W |              |         |  |  |  |
|          | SMB2_DATA SMBus channel 2 start condition detection flag. Set when start condition is detected.<br>Write '0' to clear. Writing '1' to this bit will be ignored. |      |                  |                                                                                                                                                       |                                   |        |                                 |              |         |  |  |  |
|          | SMB1_DAT                                                                                                                                                        | A    | SMBus<br>detecte | SMBus channel 1 start condition detection flag. Set when start condition is detected.<br>Write '0' to clear. Writing '1' to this bit will be ignored. |                                   |        |                                 |              |         |  |  |  |

#### 8.3.15 Wakeup Source B Mask Register (WSRCBMSK)

| Location |       | 7       | 6       | 5 | 4 | 3       | 2      | 1     | 0     |
|----------|-------|---------|---------|---|---|---------|--------|-------|-------|
|          | Read  | FAN2MSK | FAN1MSK |   |   | LRESET_ | aLPCIN | SMB2_ | SMB1_ |
| 7F2DH    | Write |         |         | - | - | MSK     | MSK    | MSK   | MSK   |
|          | Reset | 0       | 0       | Х | Х | 0       | Х      | 0     | 0     |

| Symbol    | Function                                                                                                           |
|-----------|--------------------------------------------------------------------------------------------------------------------|
| -         | Not implemented                                                                                                    |
| Х         | Not defined                                                                                                        |
| FAN2MSK,, | Wakeup and Interrupt Source Mask                                                                                   |
| SMB1_MSK  | 1: Enable Wakeup and Interrupt from the respective source in WSRCB register<br>0: Mask Wakeup and Interrupt source |

#### 8.3.16 Keyboard Wakeup Control Register (KEYWSRC)

|          |        | • | 5                                                                                | •           | ,                                           |            |            |        |     |  |  |  |  |
|----------|--------|---|----------------------------------------------------------------------------------|-------------|---------------------------------------------|------------|------------|--------|-----|--|--|--|--|
| Location |        | 7 | 6                                                                                | 5           | 4                                           | 3          | 2          | 1      | 0   |  |  |  |  |
|          | Read   |   |                                                                                  |             |                                             |            |            | KEYMSK | KEY |  |  |  |  |
| 7F2FH    | Write  | - | -                                                                                | -           | -                                           | -          | -          |        |     |  |  |  |  |
|          | Reset  | Х | Х                                                                                | Х           | Х                                           | Х          | Х          | 0      | 0   |  |  |  |  |
| Symbol   |        |   | Functio                                                                          | on          |                                             |            |            |        |     |  |  |  |  |
|          | -      |   | Not implemented                                                                  |             |                                             |            |            |        |     |  |  |  |  |
|          | Х      |   | Not defi                                                                         | Not defined |                                             |            |            |        |     |  |  |  |  |
|          | KEYMSK |   | 1: Énab                                                                          | le Wake up  | and Interrup<br>and Interrup<br>oke Wake up | t when KEY | bit is set |        |     |  |  |  |  |
|          | KEY    |   | Keystroke press detection flag. Set when falling edge on any scanner input lines |             |                                             |            |            |        |     |  |  |  |  |



#### 8.3.17 Wakeup Source C Register (WSRCC)

| Location |       | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|          | Read  | GPIO7 | GPIO6 | GPIO5 | GPIO4 | GPIO3 | GP102 | GPIO1 | GPIO0 |
| 7F59H    | Write |       |       |       |       |       |       |       |       |
|          | Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

Symbol GPIO[7:0] Function

GPIO active edge detection flag. Set when selected edge is detected. Write 0 to clear. Writing 1 to this bit will be ignored.

#### 8.3.18 Wakeup Source C Mask Register (WSRCCMSK)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | GPIO7_ | GPIO6_ | GPIO5_ | GPIO4_ | GPIO3_ | GPIO2_ | GPIO1_ | GPIO0_ |
| 7F5AH    | Write | MSK    |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol

GPIO[7:0]\_MSK

#### Function

GPIO Wakeup and Interrupt Source Mask

1: Enable Wakeup and Interrupt when GPIO edge detection flag is set 0: Mask GPIO Wakeup and Interrupt

#### 8.3.19 GPIO Active Edge Selection Register A (GPIOESA)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | GPIO7_ | GPIO6_ | GPIO5_ | GPIO4_ | GPIO3_ | GPIO2_ | GPIO1_ | GPIO0_ |
| 7F57H    | Write | ES     |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol

GPIO[7:0]\_ES

#### Function

GPIO active edge control bit

1: Select Rising edge (Low to High transition)

0: Select Falling edge (High to Low transition)

#### 8.3.20 Wakeup Source D Register (WSRCD)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1     | 0     |
|----------|-------|--------|--------|--------|--------|--------|--------|-------|-------|
|          | Read  | GPIO15 | GPIO14 | GPIO13 | GPIO12 | GPIO11 | GPIO10 | GPIO9 | GPIO8 |
| 7F5EH    | Write |        |        |        |        |        |        |       |       |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |

Symbol

GPIO[15:8]

#### Function



#### 8.3.21 Wakeup Source D Mask Register (WSRCDMSK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1      | 0      |
|----------|-------|---------|---------|---------|---------|---------|---------|--------|--------|
|          | Read  | GPIO15_ | GPIO14_ | GPIO13_ | GPIO12_ | GPIO11_ | GPIO10_ | GPIO9_ | GPIO8_ |
| 7F5FH    | Write | MSK     | MSK     | MSK     | MSK     | MSK     | MSK     | MSK    | MSK    |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0      | 0      |

Symbol

#### Function

GPIO[15:8] MSK

**GPIO Wakeup and Interrupt Source Mask** 1: Enable Wakeup and Interrupt when GPIO edge detection flag is set

0: Mask GPIO Wakeup and Interrupt

#### 8.3.22 GPIO Active Edge Selection Register B (GPIOESB)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1      | 0      |
|----------|-------|---------|---------|---------|---------|---------|---------|--------|--------|
|          | Read  | GPIO15_ | GPIO14_ | GPIO13_ | GPIO12_ | GPIO11_ | GPIO10_ | GPIO9_ | GPIO8_ |
| 7F58H    | Write | ES      | ES      | ES      | ES      | ES      | ES      | ES     | ES     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0      | 0      |

Symbol

GPIO[15:8]\_ES

#### Function

GPIO active edge control bit

1: Select Rising edge (Low to High transition) 0: Select Falling edge (High to Low transition)

#### 8.3.23 Wakeup Source E Register (WSRCE)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | GPIO23 | GPIO22 | GPIO21 | GPIO20 | GPIO19 | GPIO18 | GPIO17 | GPIO16 |
| 7F63H    | Write |        |        |        |        |        |        |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol GPIO[23:16]

#### Function

GPIO active edge detection flag. Set when selected edge is detected. Write 0 to clear. Writing 1 to this bit will be ignored.

#### 8.3.24 Wakeup Source E Mask Register (WSRCEMSK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO23_ | GPIO22_ | GPIO21_ | GPIO20_ | GPIO19_ | GPIO18_ | GPIO17_ | GPIO16_ |
| 7F66H    | Write | MSK     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

GPIO[23:16]\_MSK

#### Function

**GPIO Wakeup and Interrupt Source Mask** 1: Enable Wakeup and Interrupt when GPIO edge detection flag is set 0: Mask GPIO Wakeup and Interrupt



#### 8.3.25 GPIO Active Edge Selection Register C (GPIOESC)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO23_ | GPIO22_ | GPIO21_ | GPIO20_ | GPIO19_ | GPIO18_ | GPIO17_ | GPIO16_ |
| 7F5CH    | Write | ES      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol GPIO[23:16] ES

#### Function

GPIO active edge control bit 1: Select Rising edge (Low to High transition)

0: Select Falling edge (High to Low transition)

#### 8.3.26 Wakeup Source F Register (WSRCF)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | GPIO31 | GPIO30 | GPIO29 | GPIO28 | GPIO27 | GPIO26 | GPIO25 | GPIO24 |
| 7F64H    | Write |        |        |        |        |        |        |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol GPIO[31:24]

#### Function

GPIO active edge detection flag. Set when selected edge is detected. Write 0 to clear. Writing 1 to this bit will be ignored.

#### 8.3.27 Wakeup Source F Mask Register (WSRCFMSK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO31_ | GPIO30_ | GPIO29_ | GPIO28_ | GPIO27_ | GPIO26_ | GPIO25_ | GPIO24_ |
| 7F65H    | Write | MSK     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function

GPIO[31:24]\_MSK

#### GPIO Wakeup and Interrupt Source Mask 1: Enable Wakeup and Interrupt when GPIO edge detection flag is set 0: Mask GPIO Wakeup and Interrupt

#### 8.3.28 GPIO Active Edge Selection Register D (GPIOESD)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO31_ | GPIO30_ | GPIO29_ | GPIO28_ | GPIO27_ | GPIO26_ | GPIO25_ | GPIO24_ |
| 7F5DH    | Write | ES      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

Function GPIO active edge control bit

GPIO[31:24]\_ES G

1: Select Rising edge (Low to High transition)

0: Select Falling edge (High to Low transition)



### 8.3.29 Wakeup Source G Register (WSRCG)

| Location |       | 7      | 6                  | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------------------|--------|--------|--------|--------|--------|--------|
|          | Read  | GPIO39 | GPIO38/            | GPIO37 | GPIO36 | GPIO35 | GPIO34 | GPIO33 | GPIO32 |
| 7F55H    | Write |        | LPCPD <sup>1</sup> |        |        |        |        |        |        |
|          | Reset | 0      | 0                  | 0      | 0      | 0      | 0      | 0      | 0      |

1. This interrupt source bit is set when active edge is detected regardless of whether GPIO38 or alternate LPCPD# function is selected

Symbol

Function

GPIO[39:32]

GPIO active edge detection flag. Set when selected edge is detected. Write 0 to clear. Writing 1 to this bit will be ignored.

#### 8.3.30 Wakeup Source G Mask Register (WSRCGMSK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO39_ | GPIO38_ | GPIO37_ | GPIO36_ | GPIO35_ | GPIO34_ | GPIO33_ | GPIO32_ |
| 7F56H    | Write | MSK     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

GPIO[39:32]\_MSK

## Function

GPIO Wakeup and Interrupt Source Mask

1: Enable Wakeup and Interrupt when GPIO edge detection flag is set 0: Mask GPIO Wakeup and Interrupt

#### 8.3.31 GPIO Active Edge Selection Register E (GPIOESE)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO39_ | GPIO38_ | GPIO37_ | GPIO36_ | GPIO35_ | GPIO34_ | GPIO33_ | GPIO32_ |
| 7F60H    | Write | ES      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

GPIO[39:32] ES

## Function

GPIO active edge control bit

1: Select Rising edge (Low to High transition)

0: Select Falling edge (High to Low transition)

## 8.3.32 Wakeup Source H Register (WSRCH)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | GPIO47 | GPIO46 | GPIO45 | GPIO44 | GPIO43 | GPIO42 | GPIO41 | GPIO40 |
| 7FAEH    | Write |        |        |        |        |        |        |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol

GPIO[47:40]

#### Function



#### 8.3.33 Wakeup Source H Mask Register (WSRCHMSK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO47_ | GPIO46_ | GPIO45_ | GPIO44_ | GPIO43_ | GPIO42_ | GPIO41_ | GPIO40_ |
| 7FAFH    | Write | MSK     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function

GPIO[47:40] MSK

**GPIO Wakeup and Interrupt Source Mask** 1: Enable Wakeup and Interrupt when GPIO edge detection flag is set 0: Mask GPIO Wakeup and Interrupt

#### 8.3.34 GPIO Active Edge Selection Register F (GPIOESF)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO47_ | GPIO46_ | GPIO45_ | GPIO44_ | GPIO43_ | GPIO42_ | GPIO41_ | GPIO40_ |
| 7F61H    | Write | ES      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

GPIO[47:40]\_ES

#### Function

GPIO active edge control bit

1: Select Rising edge (Low to High transition) 0: Select Falling edge (High to Low transition)

#### 8.3.35 Wakeup Source I Register (WSRCI)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | GPIO55 | GPIO54 | GPIO53 | GPIO52 | GPIO51 | GPIO50 | GPIO49 | GPIO48 |
| 7F3EH    | Write |        |        |        |        |        |        |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol GPIO[55:48]

#### Function

GPIO active edge detection flag. Set when selected edge is detected. Write 0 to clear. Writing 1 to this bit will be ignored.

#### 8.3.36 Wakeup Source I Mask Register (WSRCIMSK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO55_ | GPIO54_ | GPIO53_ | GPIO52_ | GPIO51_ | GPIO50_ | GPIO49_ | GPIO48_ |
| 7F3FH    | Write | MSK     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

GPIO[55:48]\_MSK

#### Function

**GPIO Wakeup and Interrupt Source Mask** 1: Enable Wakeup and Interrupt when GPIO edge detection flag is set 0: Mask GPIO Wakeup and Interrupt



### 8.3.37 GPIO Active Edge Selection Register G (GPIOESG)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO55_ | GPIO54_ | GPIO53_ | GPIO52_ | GPIO51_ | GPIO50_ | GPIO49_ | GPIO48_ |
| 7F62H    | Write | ES      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function

GPIO[55:48] ES

GPIO active edge control bit

1: Select Rising edge (Low to High transition) 0: Select Falling edge (High to Low transition)

#### 8.3.38 Wakeup Source J Register (WSRCJ)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | GPIO63 | GPIO62 | GPIO61 | GPIO60 | GPIO59 | GPIO58 | GPIO57 | GPIO56 |
| 7FC8H    | Write |        |        |        |        |        |        |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol GPIO[63:56]

#### Function

GPIO active edge detection flag. Set when selected edge is detected. Write 0 to clear. Writing 1 to this bit will be ignored.

#### 8.3.39 Wakeup Source J Mask Register (WSRCJMSK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO63_ | GPIO62_ | GPIO61_ | GPIO60_ | GPIO59_ | GPIO58_ | GPIO57_ | GPIO56_ |
| 7FC9H    | Write | MSK     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

#### Symbol

GPIO[63:56] MSK

### **Function**

**GPIO Wakeup and Interrupt Source Mask** 1: Enable Wakeup and Interrupt when GPIO edge detection flag is set 0: Mask GPIO Wakeup and Interrupt

#### 8.3.40 GPIO Active Edge Selection Register H (GPIOESH)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO63_ | GPIO62_ | GPIO61_ | GPIO60_ | GPIO59_ | GPIO58_ | GPIO57_ | GPIO56_ |
| 7F6CH    | Write | ES      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

#### Symbol

GPIO[63:56]\_ES

## **Function**

GPIO active edge control bit 1: Select Rising edge (Low to High transition) 0: Select Falling edge (High to Low transition)

#### 8.3.41 Wakeup Source K Register (WSRCK)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | GPIO71 | GPIO70 | GPIO69 | GPIO68 | GPIO67 | GPIO66 | GPIO65 | GPIO64 |
| 7FCAH    | Write |        |        |        |        |        |        |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

## Symbol

**Function** 

GPIO[71:64]



#### 8.3.42 Wakeup Source K Mask Register (WSRCKMSK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO71_ | GPIO70_ | GPIO69_ | GPIO68_ | GPIO67_ | GPIO66_ | GPIO65_ | GPIO64_ |
| 7FCBH    | Write | MSK     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function

GPIO[71:64]\_MSK

GPIO Wakeup and Interrupt Source Mask 1: Enable Wakeup and Interrupt when GPIO edge detection flag is set 0: Mask GPIO Wakeup and Interrupt

#### 8.3.43 GPIO Active Edge Selection Register I (GPIOESI)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO67_ | GPIO67_ | GPIO66_ | GPIO66_ | GPIO65_ | GPIO65_ | GPIO64_ | GPIO64_ |
| 7F6DH    | Write | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function

GPIO[67:64]\_ES[1:0]

#### GPIO active edge control bit

01: Select Rising edge (Low to High transition)

10: Select Both Falling and Rising Edges

00 or 11: Select Falling edge (High to Low transition)

#### 8.3.44 GPIO Active Edge Selection Register J (GPIOESJ)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO71_ | GPIO71_ | GPIO70_ | GPIO70_ | GPIO69_ | GPIO69_ | GPIO68_ | GPIO68_ |
| 7F6EH    | Write | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function

GPIO active edge control bit

01: Select Rising edge (Low to High transition)

10: Select Both Falling and Rising Edges

00 or 11: Select Falling edge (High to Low transition)

### 8.3.45 Wakeup Source L Register (WSRCL)

GPIO[71:68]\_ES[1:0]

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | GPIO79 | GPIO78 | GPIO77 | GPIO76 | GPIO75 | GPIO74 | GPIO73 | GPIO72 |
| 7FCCH    | Write |        |        |        |        |        |        |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol GPIO[79:72]

### Function



#### 8.3.46 Wakeup Source L Mask Register (WSRCLMSK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO79_ | GPIO78_ | GPIO77_ | GPIO76_ | GPIO75_ | GPIO74_ | GPIO73_ | GPIO72_ |
| 7FCDH    | Write | MSK     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function

GPIO[79:72]\_MSK

**GPIO Wakeup and Interrupt Source Mask** 1: Enable Wakeup and Interrupt when GPIO edge detection flag is set 0: Mask GPIO Wakeup and Interrupt

#### 8.3.47 GPIO Active Edge Selection Register K (GPIOESK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO75_ | GPIO75_ | GPIO74_ | GPIO74_ | GPIO73_ | GPIO73_ | GPIO72_ | GPIO72_ |
| 7F6FH    | Write | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function GPIO[75:72]\_ES[1:0]

GPIO active edge control bit

01: Select Rising edge (Low to High transition)

10: Select Both Falling and Rising Edges

00 or 11: Select Falling edge (High to Low transition)

#### 8.3.48 GPIO Active Edge Selection Register L (GPIOESL)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO79_ | GPIO79_ | GPIO78_ | GPIO78_ | GPIO77_ | GPIO77_ | GPIO76_ | GPIO76_ |
| 7FD0H    | Write | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

### Function

GPIO[79:76]\_ES[1:0]

#### GPIO active edge control bit

01: Select Rising edge (Low to High transition)

10: Select Both Falling and Rising Edges

00 or 11: Select Falling edge (High to Low transition)

#### 8.3.49 Wakeup Source M Register (WSRCM)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | GPIO87 | GPIO86 | GPIO85 | GPIO84 | GPIO83 | GPIO82 | GPIO81 | GPIO80 |
| 7FCEH    | Write |        |        |        |        |        |        |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol GPIO[87:80]

#### Function



#### 8.3.50 Wakeup Source M Mask Register (WSRCMMSK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO87_ | GPIO86_ | GPIO85_ | GPIO84_ | GPIO83_ | GPIO82_ | GPIO81_ | GPIO80_ |
| 7FCFH    | Write | MSK     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function

GPIO[87:80] MSK

**GPIO Wakeup and Interrupt Source Mask** 1: Enable Wakeup and Interrupt when GPIO edge detection flag is set 0: Mask GPIO Wakeup and Interrupt

#### 8.3.51 GPIO Active Edge Selection Register M (GPIOESM)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO83_ | GPIO83_ | GPIO82_ | GPIO82_ | GPIO81_ | GPIO81_ | GPIO80_ | GPIO80_ |
| 7FD1H    | Write | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### GPIO[83:80]\_ES[1:0]

## Function

GPIO active edge control bit

01: Select Rising edge (Low to High transition)

10: Select Both Falling and Rising Edges

00 or 11: Select Falling edge (High to Low transition)

#### 8.3.52 GPIO Active Edge Selection Register N (GPIOESN)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO87_ | GPIO87_ | GPIO86_ | GPIO86_ | GPIO85_ | GPIO85_ | GPIO84_ | GPIO84_ |
| 7FD2H    | Write | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

### Function

GPIO[87:84]\_ES[1:0]

#### GPIO active edge control bit

01: Select Rising edge (Low to High transition)

10: Select Both Falling and Rising Edges

00 or 11: Select Falling edge (High to Low transition)

## 8.3.53 GPIO K Interrupt Selection Register (GPIOKINT)

| Location |       | 7 | 6 | 5        | 4        | 3        | 2        | 1        | 0        |
|----------|-------|---|---|----------|----------|----------|----------|----------|----------|
|          | Read  |   |   | GPIO85IN | GPIO84IN | GPIO83IN | GPIO82IN | GPIO81IN | GPIO80IN |
| 7FB8H    | Write | - | - | Т        | Т        | Т        | Т        | Т        | Т        |
|          | Reset | Х | Х | 0        | 0        | 0        | 0        | 0        | 0        |

Symbol

Х

## Function

Not implemented

Not defined

GPIO[85:80]INT

**GPIO** Interrupt control bit

1: GPIO active edge detection generates INT0 (combined with any KEY press detection interrupt)

0: GPIO active edge detection generates INT5 (as shown on Figure 8-1)



#### 8.3.54 Wakeup Source N Register (WSRCN)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | GPIO95 | GPIO94 | GPIO93 | GPIO92 | GPIO91 | GPIO90 | GPIO89 | GPIO88 |
| 7FB0H    | Write |        |        |        |        |        |        |        |        |
|          | Reset | Х      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol X Function

GPIO[95:88]

### Not defined

GPIO active edge detection flag. Set when selected edge is detected. Write 0 to clear. Writing 1 to this bit will be ignored.

#### 8.3.55 Wakeup Source N Mask Register (WSRCNMSK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO95_ | GPIO94_ | GPIO93_ | GPIO92_ | GPIO91_ | GPIO90_ | GPIO89_ | GPIO88_ |
| 7FB1H    | Write | MSK     |
|          | Reset | Х       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol X

## Function

Not defined

GPIO[95:88]\_MSK

DIO Wakaun and Interrun

GPIO Wakeup and Interrupt Source Mask

1: Enable Wakeup and Interrupt when GPIO edge detection flag is set 0: Mask GPIO Wakeup and Interrupt

#### 8.3.56 GPIO Active Edge Selection Register O (GPIOESO)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO91_ | GPIO91_ | GPIO90_ | GPIO90_ | GPIO89_ | GPIO89_ | GPIO88_ | GPIO88_ |
| 7FD3H    | Write | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

GPIO[91:88]\_ES[1:0]

**Function** GPIO active edge control bit

01: Select Rising edge (Low to High transition)

10: Select Both Falling and Rising Edges

00 or 11: Select Falling edge (High to Low transition)

#### 8.3.57 GPIO Active Edge Selection Register P (GPIOESP)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO95_ | GPIO95_ | GPIO94_ | GPIO94_ | GPIO93_ | GPIO93_ | GPIO92_ | GPIO92_ |
| 7FD4H    | Write | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function

GPIO[95:92]\_ES[1:0] GPIO active edge control bit

01: Select Rising edge (Low to High transition)

10: Select Both Falling and Rising Edges

00 or 11: Select Falling edge (High to Low transition)



#### 8.3.58 Wakeup Source O Register (WSRCO)

| Location |       | 7       | 6       | 5       | 4       | 3      | 2      | 1      | 0      |
|----------|-------|---------|---------|---------|---------|--------|--------|--------|--------|
|          | Read  | GPIO103 | GPIO102 | GPIO101 | GPIO100 | GPIO99 | GPIO98 | GPIO97 | GPIO96 |
| 7FDBH    | Write |         |         |         |         |        |        |        |        |
|          | Reset | 0       | 0       | 0       | 0       | 0      | 0      | 0      | 0      |

Symbol GPIO[103:96]

#### Function

GPIO active edge detection flag. Set when selected edge is detected. Write 0 to clear. Writing 1 to this bit will be ignored.

#### 8.3.59 Wakeup Source O Mask Register (WSRCOMSK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO103 | GPIO102 | GPIO101 | GPIO100 | GPIO99_ | GPIO98_ | GPIO97_ | GPIO96_ |
| 7FECH    | Write | _MSK    | _MSK    | _MSK    | _MSK    | MSK     | MSK     | MSK     | MSK     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function

GPIO[103:96]\_MSK

GPIO Wakeup and Interrupt Source Mask 1: Enable Wakeup and Interrupt when GPIO edge detection flag is set 0: Mask GPIO Wakeup and Interrupt

## 8.3.60 GPIO Active Edge Selection Register Q (GPIOESQ)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO99_ | GPIO99_ | GPIO98_ | GPIO98_ | GPIO97_ | GPIO97_ | GPIO96_ | GPIO96_ |
| 7FD5H    | Write | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     | ES1     | ES0     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

GPIO[99:96] ES[1:0]

#### Function

GPIO active edge control bit

01: Select Rising edge (Low to High transition)

10: Select Both Falling and Rising Edges

00 or 11: Select Falling edge (High to Low transition)

#### 8.3.61 GPIO Active Edge Selection Register R (GPIOESR)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO103 | GPIO103 | GPIO102 | GPIO102 | GPIO101 | GPIO101 | GPIO100 | GPIO100 |
| 7FD6H    | Write | _ES1    | _ES0    | _ES1    | _ES0    | _ES1    | _ES0    | _ES1    | _ES0    |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

## Function

GPIO[103:100] \_ES[1:0]

## GPIO active edge control bit

01: Select Rising edge (Low to High transition)

10: Select Both Falling and Rising Edges

00 or 11: Select Falling edge (High to Low transition)



#### 8.3.62 Wakeup Source P Register (WSRCP)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO111 | GPIO110 | GPIO109 | GPIO108 | GPIO107 | GPIO106 | GPIO105 | GPIO104 |
| 7FEDH    | Write |         |         |         |         |         |         |         |         |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol GPIO[111:104]

#### Function

GPIO active edge detection flag. Set when selected edge is detected. Write 0 to clear. Writing 1 to this bit will be ignored.

### 8.3.63 Wakeup Source P Mask Register (WSRCPMSK)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO111 | GPIO110 | GPIO109 | GPIO108 | GPIO107 | GPIO106 | GPIO105 | GPIO104 |
| 7FEEH    | Write | _MSK    |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

GPIO[111:104]\_MSK

#### Function

GPIO Wakeup and Interrupt Source Mask 1: Enable Wakeup and Interrupt when GPIO edge detection flag is set 0: Mask GPIO Wakeup and Interrupt

## 8.3.64 GPIO Active Edge Selection Register S (GPIOESS)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO107 | GPIO107 | GPIO106 | GPIO106 | GPIO105 | GPIO105 | GPIO104 | GPIO104 |
| 7FD7H    | Write | _ES1    | _ES0    | _ES1    | _ES0    | _ES1    | _ES0    | _ES1    | _ES0    |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

\_ES[1:0]

GPIO[107:104]

#### Function

GPIO active edge control bit

01: Select Rising edge (Low to High transition)

10: Select Both Falling and Rising Edges

00 or 11: Select Falling edge (High to Low transition)

#### 8.3.65 GPIO Active Edge Selection Register T (GPIOEST)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO111 | GPIO111 | GPIO110 | GPIO110 | GPIO109 | GPIO109 | GPIO108 | GPIO108 |
| 7FD8H    | Write | _ES1    | _ES0    | _ES1    | _ES0    | _ES1    | _ES0    | _ES1    | _ES0    |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol GPIO[111:108]

ES[1:0]

#### Function

GPIO active edge control bit

01: Select Rising edge (Low to High transition)

10: Select Both Falling and Rising Edges

00 or 11: Select Falling edge (High to Low transition)

## 9.0 GPIO PORTS

The SST79LF008 has 112 general purpose input/output pins (GPIOs); 77 pins are multiplexed with alternate functions, as shown in to Figure 2-1, and 35 pins are dedicated GPIOs. All GPIO pins also generate 8051 Interrupt and Wake up events. See Section 8.0 for additional information on Interrupt and Wake up control.

Use the GPIO Function Selection Registers to select either the GPIO function or an alternate function for the corresponding pins. When an alternate function is selected the direction of the pin as well as output data is determined by the peripheral module that controls the alternate function.

When selecting the GPIO function, the direction of the pin is determined by the respective GPIO Direction Register, and the output data for output pins is specified by the respective Output Register. In other words, the status of the pin is controlled by the data in the GPIO Output Register when the GPIO function is selected and output direction is specified). No direction control is provided for GPI43-GPI45 pins, which are always configured as inputs. Also, no direction control is provided for the GPIO16-GPIO22, GPIO28-GPIO39, and GPIO40 pins with open drain buffers, which are always configured as outputs. **Note:** When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

GPIO60-GPIO79, GPIO88-GPIO91, and GPIO96-GPIO111 with push-pull buffers can be used to emulate open drain configuration by tri-stating the push-pull buffer when output data is '1'. The respective open-drain/push-pull selection registers control buffer configuration for these pins.

GPIO80-GPIO85 and GPIO94-GPIO111 have programmable pull-up resistors, which can be enabled/disabled by the respective pull-up control registers.

For most pins, reading the GPIO input registers will return the status of the pins, regardless of selected function. The only exceptions being, GPIO68-GPIO71 and GPIO72-GPIO79 are multiplexed with DAC outputs or ADC inputs are the only exceptions. These pins can be read via input registers in the GPIO mode only. Reading the input register when DAC or ADC alternate function is enabled will return an indeterminate value.

For detailed information on GPIO control registers refer to Section 9.1. See also, the GPIO buffer types list in Table 2-1 and Table 2-2.

## 9.1 GPIO CONTROL REGISTERS

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| 754011   | Read  | GPIO7_ | GPIO6_ | GPIO5_ | GPIO4_ | GPIO3_ | GPIO2_ | GPIO1_ | GPIO0_ |
| 7F18H    | Write | DiR    |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

## 9.1.1 GPIO A Direction Register (GPIOADIR)

**Symbol** GPIO[7:0]\_DIR Function

GPIO direction control bit 1: Output 0: Input

#### 9.1.2 GPIO A Input Register (GPIOAIN)<sup>1</sup>

| Location |       | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
|----------|-------|----------|----------|----------|----------|----------|----------|----------|----------|
|          | Read  | GPIO7_IN | GPIO6_IN | GPIO5_IN | GPIO4_IN | GPIO3_IN | GPIO2_IN | GPIO1_IN | GPIO0_IN |
| 7F1AH    | Write | -        | -        | -        | -        | -        | -        | -        | -        |
|          | Reset | GPIO7_IN | GPIO6_IN | GPIO5_IN | GPIO4_IN | GPIO3_IN | GPIO2_IN | GPIO1_IN | GPIO0_IN |

1. When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

Symbol

Function

GPIO[7:0]\_IN

Not implemented When read, returns the status of the pin.

©2006 Silicon Storage Technology, Inc.



#### 9.1.3 GPIO A Output Register (GPIOAOUT)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | GPIO7_ | GPIO6_ | GPIO5_ | GPIO4_ | GPIO3_ | GPIO2_ | GPIO1_ | GPIO0_ |
| 7F19H    | Write | OUT    |
|          | Reset | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |

Symbol GPIO[7:0]\_OUT

#### Function

When written to, output data is updated. When read, returns previously written data.

#### 9.1.4 GPIO A Function Select Register (GPIOASEL)

| Location |           | 7      | 6       | 5                           | 4                 | 3              | 2               | 1      | 0      |
|----------|-----------|--------|---------|-----------------------------|-------------------|----------------|-----------------|--------|--------|
|          | Read      | GPIO7_ | GPIO6_  | GPIO5_                      | GPIO4_            | GPIO3_         | GPIO2_          | GPIO1_ | GPIO0_ |
| 7F3DH    | Write     | SEL    | SEL     | SEL                         | SEL               | SEL            | SEL             | SEL    | SEL    |
|          | Reset     | 0      | 0       | 0                           | 0                 | 0              | 0               | 0      | 0      |
|          | Symbol    |        | Functio | n                           |                   |                |                 |        |        |
|          | GPIO7_SEL | _      | 1: GA20 | ) (Gate A20                 | output)           |                |                 |        |        |
|          |           |        |         | 07 function                 |                   |                |                 |        |        |
|          | GPIO6_SEL | -      |         | · ·                         | elect input fo    | or SPI)        |                 |        |        |
|          |           |        |         | 06 function                 |                   |                |                 |        |        |
|          | GPIO5_SEL | -      |         | (Master cloc<br>)5 function | k output, sla     | ve clock inpl  | It pin for SPI  | )      |        |
|          | GPIO4 SEL |        |         |                             | ta input pin, s   | alava data a   | itout nin for ( | 201)   |        |
|          | GF104_3EL | -      |         | 9 (Master ua<br>)4 function | ia iliput pili, s | Slave Uala Ul  |                 | 551)   |        |
|          | GPIO3 SEL | _      |         |                             | ta output pin     | . slave data i | nput pin for S  | SPI)   |        |
|          |           |        |         | 03 function                 |                   | ,              | F. F            | - /    |        |
|          | GPIO2_SEL | _      | 1: PWM  | 12 (Pulse Wi                | dth Modulato      | or output 2)   |                 |        |        |
|          |           |        | 0: GPIC | 02 function                 |                   |                |                 |        |        |
|          | GPIO1_SEL | -      |         | •                           | dth Modulato      | or output 1)   |                 |        |        |
|          |           |        |         | )1 function                 |                   |                |                 |        |        |
|          | GPIO0_SEL | -      |         | 10 (Pulse Wi<br>00 function | dth Modulato      | or output ()   |                 |        |        |
|          |           |        | U. GFIC |                             |                   |                |                 |        |        |

## 9.1.5 GPIO B Direction Register (GPIOBDIR)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1      | 0      |
|----------|-------|---------|---------|---------|---------|---------|---------|--------|--------|
|          | Read  | GPIO15_ | GPIO14_ | GPIO13_ | GPIO12_ | GPIO11_ | GPIO10_ | GPIO9_ | GPIO8_ |
| 7F1BH    | Write | DIR     | DIR     | DIR     | DIR     | DIR     | DIR     | DIR    | DIR    |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0      | 0      |

124

Symbol GPIO[15:8]\_DIR

## Function

GPIO direction control bit 1: Output 0: Input

S71320-01-000



#### 9.1.6 GPIO B Input Register (GPIOBIN)<sup>1</sup>

| Location |       | 7             | 6             | 5             | 4             | 3             | 2             | 1            | 0            |
|----------|-------|---------------|---------------|---------------|---------------|---------------|---------------|--------------|--------------|
| 7F1DH    | Read  | GPIO15_<br>IN | GPIO14_<br>IN | GPIO13_<br>IN | GPIO12_<br>IN | GPIO11_<br>IN | GPIO10_<br>IN | GPIO9_<br>IN | GPIO8_<br>IN |
|          | Write | -             | -             | -             | -             | -             | -             | -            | -            |
|          | Reset | GPIO15_<br>IN | GPIO14_<br>IN | GPIO13_<br>IN | GPIO12_<br>IN | GPIO11_<br>IN | GPIO10_<br>IN | GPIO9_<br>IN | GPIO8_<br>IN |

1. When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

#### Symbol

Function

GPIO[15:8]\_IN

Not implemented

When read, returns the status of the pin.

#### 9.1.7 GPIO B Output Register (GPIOBOUT)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1      | 0      |
|----------|-------|---------|---------|---------|---------|---------|---------|--------|--------|
|          | Read  | GPIO15_ | GPIO14_ | GPIO13_ | GPIO12_ | GPIO11_ | GPIO10_ | GPIO9_ | GPIO8_ |
| 7F1CH    | Write | OUT     | OUT     | OUT     | OUT     | OUT     | OUT     | OUT    | OUT    |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1      | 1      |

Symbol GPIO[15:8]\_OUT

#### Function

When written to, output data is updated. When read, returns previously written data.

## 9.1.8 GPIO B Function Select Register (GPIOBSEL)

| Location |            | 7       | 6       | 5                                                                          | 4              | 3              | 2       | 1 | 0 |  |  |
|----------|------------|---------|---------|----------------------------------------------------------------------------|----------------|----------------|---------|---|---|--|--|
|          | Read       | GPIO15_ | GPIO14_ | GPIO13_                                                                    | GPIO12_        | GPIO11_        | GPIO10_ | - | - |  |  |
| 7F40H    | Write      | SEL     | SEL     | SEL                                                                        | SEL            | SEL            | SEL     |   |   |  |  |
|          | Reset      | 0       | 0       | 0                                                                          | 0              | 0              | 0       | Х | Х |  |  |
|          | Symbol     |         | Functio | on                                                                         |                |                |         |   |   |  |  |
|          | -          |         | Not imp | lemented                                                                   |                |                |         |   |   |  |  |
|          | Х          |         | Not def | ned                                                                        |                |                |         |   |   |  |  |
|          | GPIO15_SEL |         |         | 1: T2EX (Timer 2 external interrupt input)                                 |                |                |         |   |   |  |  |
|          |            |         |         | 015 function                                                               |                |                |         |   |   |  |  |
|          | GPIO14_SEL |         |         | •                                                                          | nterface statu | is signal outp | out 2)  |   |   |  |  |
|          |            |         |         | 0: GPIO14 function                                                         |                |                |         |   |   |  |  |
|          | GPIO13_SE  | EL      |         | 1: SS1 (LPC Host interface status signal output 1)                         |                |                |         |   |   |  |  |
|          |            |         |         | 0: GPIO13 function                                                         |                |                |         |   |   |  |  |
|          | GPIO12_SE  | =L      |         | 1: SS0 (LPC Host interface status signal output 0)                         |                |                |         |   |   |  |  |
|          |            |         |         | 0: GPIO12 function                                                         |                |                |         |   |   |  |  |
|          | GPIO11_SEL |         |         | 1: KBRST#. (Keyboard Controller reset to CPU output)<br>0: GPIO11 function |                |                |         |   |   |  |  |
|          | GPIO10 SE  | =1      |         |                                                                            |                |                |         |   |   |  |  |
|          | GFI010_30  |         |         | 1: ECLK (External clock input)<br>0: GPI010 function                       |                |                |         |   |   |  |  |
|          |            |         | 0.0110  |                                                                            |                |                |         |   |   |  |  |



### 9.1.9 LPC Status Signals Output Control Register (LPCSS)

| Location |       | 7      | 6           | 5         | 4 | 3 | 2     | 1     | 0     |  |
|----------|-------|--------|-------------|-----------|---|---|-------|-------|-------|--|
|          | Read  | -      | -           | -         | - | - | SSEL2 | SSEL1 | SSEL0 |  |
| 7FDFH    | Write |        |             |           |   |   |       |       |       |  |
|          | Reset | Х      | Х           | Х         | Х | Х | 0     | 0     | 0     |  |
| Symbol   |       | Functi | on          |           |   |   |       |       |       |  |
|          | -     |        | Not imp     | olemented |   |   |       |       |       |  |
| Х        |       |        | Not defined |           |   |   |       |       |       |  |

SSEL[2:0] LPC Host status signals selection bits

#### 9-1: LPC Host Status Signals as a Function of SSEL[2:0] TABLE

| SSEL2 SSEL1 SSEL0 | SS0# Output                     | SS1# Output                     | SS2# Output                           |
|-------------------|---------------------------------|---------------------------------|---------------------------------------|
| 000               | KBCSTS[IBF or OBF] <sup>1</sup> | ECISTS[IBF or OBF] <sup>1</sup> | Mailbox Interrupt Status <sup>2</sup> |
| 001               | KBCSTS[IBF or OBF]              | Mailbox Interrupt Status        | ECISTS[IBF or OBF]                    |
| 010               | ECISTS[IBF or OBF]              | KBCSTS[IBF or OBF]              | Mailbox Interrupt Status              |
| 011               | ECISTS[IBF or OBF]              | Mailbox Interrupt Status        | KBCSTS[IBF or OBF]                    |
| 100               | Mailbox Interrupt Status        | KBCSTS[IBF or OBF]              | ECISTS[IBF or OBF]                    |
| 101               | Mailbox Interrupt Status        | ECISTS[IBF or OBF]              | KBCSTS[IBF or OBF]                    |
| 110-111           | Reserved                        | Reserved                        | Reserved                              |

1. Asserted when either IBF or OBF flag in the respective status register is set '1' (see also Sections 18.0, 20.0).

2. Asserted when either Host to 8051 or 8051 to Host interrupt is pending (see also Section 21.0).

#### 9.1.10 GPIO C Direction Register (GPIOCDIR)

| Location |       | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|-------|---------|---|---|---|---|---|---|---|
|          | Read  | GPIO23_ | - | - | - | - | - | - | - |
| 7F1EH    | Write | DIR     |   |   |   |   |   |   |   |
|          | Reset | 0       | Х | Х | Х | Х | Х | Х | Х |

Symbol Х

## **Function-**

| -          | Not implemented            |
|------------|----------------------------|
| Х          | Not defined                |
| GPIO23_DIR | GPIO direction control bit |
|            | 1: Output                  |
|            | 0: Input                   |

#### 9.1.11 GPIO C Input Register (GPIOCIN)<sup>1</sup>

| Location |       | 7             | 6             | 5             | 4             | 3             | 2             | 1             | 0             |
|----------|-------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| 7F20H    | Read  | GPIO23_<br>IN | GPIO22_<br>IN | GPIO21_<br>IN | GPIO20_<br>IN | GPIO19_<br>IN | GPIO18_<br>IN | GPIO17_<br>IN | GPIO16_<br>IN |
|          | Write | -             | -             | -             | -             | -             | -             | -             | -             |
|          | Reset | GPIO23_<br>IN | GPIO22_<br>IN | GPIO21_<br>IN | GPIO20_<br>IN | GPIO19_<br>IN | GPIO18_<br>IN | GPIO17_<br>IN | GPIO16_<br>IN |

1. When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

Symbol

Function

GPIO[23:16]\_IN

Not implemented When read, returns the status of the pin



## 9.1.12 GPIO C Output Register (GPIOCOUT)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO23_ | GPIO22_ | GPIO21_ | GPIO20_ | GPIO19_ | GPIO18_ | GPIO17_ | GPIO16_ |
| 7F1FH    | Write | OUT     |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

Symbol GPIO[23:16]\_OUT Function

When written to, output data is updated. When read, returns previously written data.

## 9.1.13 GPIO C Function Select Register (GPIOCSEL)

| Location |       | 7 | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | - | GPIO22_ | GPIO21_ | GPIO20_ | GPIO19_ | GPIO18_ | GPIO17_ | GPIO16_ |
| 7FDCH    | Write |   | SEL     |
|          | Reset | Х | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

| Symbol     | Function                                                              |
|------------|-----------------------------------------------------------------------|
| -          | Not implemented                                                       |
| Х          | Not defined                                                           |
| GPIO22_SEL | 1: EC_SCI# (ACPI EC channel 0 interrupt output)<br>0: GPIO22 function |
| GPIO21_SEL | 1: SMI# (System Management Interrupt output)<br>0: GPIO21 function    |
| GPIO20_SEL | 1: LED4 output<br>0: GPIO20 function                                  |
| GPIO19_SEL | 1: LED3 output<br>0: GPIO19 function                                  |
| GPIO18_SEL | 1: LED2 output<br>0: GPIO18 function                                  |
| GPIO17_SEL | 1: LED1 output<br>0: GPIO17 function                                  |
| GPIO16_SEL | 1: LED0 output<br>0: GPIO16 function                                  |

#### 9.1.14 GPIO D Direction Register (GPIODDIR)

| Location |       | 7 | 6 | 5 | 4 | 3       | 2       | 1       | 0       |
|----------|-------|---|---|---|---|---------|---------|---------|---------|
|          | Read  | - | - | - | - | GPIO27_ | GPIO26_ | GPIO25_ | GPIO24_ |
| 7F22H    | Write |   |   |   |   | DIR     | DIR     | DIR     | DIR     |
|          | Reset | Х | Х | Х | Х | 0       | 0       | 0       | 0       |

| Symbol          |
|-----------------|
| -               |
| Х               |
| GPIO[27:24]_DIR |

## Function

Not implemented Not defined GPIO direction control bit 1: Output 0: Input



#### 9.1.15 GPIO D Input Register (GPIODIN)<sup>1</sup>

| Location |       | 7             | 6             | 5             | 4             | 3             | 2             | 1             | 0             |
|----------|-------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| 7F24H    | Read  | GPIO31_<br>IN | GPIO30_<br>IN | GPIO29_<br>IN | GPIO28_<br>IN | GPIO27_<br>IN | GPIO26_<br>IN | GPIO25_<br>IN | GPIO24_<br>IN |
|          | Write | -             | -             | -             | -             | -             | -             | -             | -             |
|          | Reset | GPIO31_<br>IN | GPIO30_<br>IN | GPIO29_<br>IN | GPIO28_<br>IN | GPIO27_<br>IN | GPIO26_<br>IN | GPIO25_<br>IN | GPIO24_<br>IN |

1. When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

#### Symbol

Function

GPIO[31:24]\_IN

Not implemented

IN When read, returns the status of the pin.

#### 9.1.16 GPIO D Output Register (GPIODOUT)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO31_ | GPIO30_ | GPIO29_ | GPIO28_ | GPIO27_ | GPIO26_ | GPIO25_ | GPIO24_ |
| 7F23H    | Write | OUT     |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

Symbol GPIO[31:24]\_OUT

### Function

When written to, output data is updated. When read, returns previously written data.

## 9.1.17 GPIO D Function Select Register (GPIODSEL)

|          | <b>5</b> ( )                                |            |                                      |                    |               |         |         |         |         |  |  |
|----------|---------------------------------------------|------------|--------------------------------------|--------------------|---------------|---------|---------|---------|---------|--|--|
| Location |                                             | 7          | 6                                    | 5                  | 4             | 3       | 2       | 1       | 0       |  |  |
|          | Read                                        | GPIO31_    | GPIO30_                              | GPIO29_            | GPIO28_       | GPIO27_ | GPIO26_ | GPIO25_ | GPIO24_ |  |  |
| 7FDDH    | Write                                       | SEL        | SEL                                  | SEL                | SEL           | SEL     | SEL     | SEL     | SEL     |  |  |
|          | Reset                                       | 0          | 0                                    | 0                  | 0             | 0       | 0       | 0       | 0       |  |  |
|          | Symbol                                      |            | Functio                              | on                 |               |         |         |         |         |  |  |
|          | GPIO31_SE                                   | ΞL         | 1: PSD                               | AT1 (PS/2 cł       | nannel 1 data | a pin)  |         |         |         |  |  |
|          |                                             |            | 0: GPIC                              | 031 function       |               | . ,     |         |         |         |  |  |
|          | GPIO30_SE                                   | EL         | 1: PSCLK1 (PS/2 channel 1 clock pin) |                    |               |         |         |         |         |  |  |
|          |                                             |            | 0: GPIC                              | 0: GPIO30 function |               |         |         |         |         |  |  |
|          | GPIO29_SE                                   | ΞL         | 1: PSD/                              | ATO (PS/2 cł       | nannel 0 data | a pin)  |         |         |         |  |  |
|          |                                             |            | 0: GPIO29 function                   |                    |               |         |         |         |         |  |  |
|          | GPIO28_SE                                   | EL         |                                      | •                  | nannel 0 cloc | x pin)  |         |         |         |  |  |
|          |                                             |            |                                      | 028 function       |               |         |         |         |         |  |  |
|          | GPIO27_SE                                   | ΞL         |                                      | 2 (SMBus 2         | data pin)     |         |         |         |         |  |  |
|          |                                             |            |                                      | 027 function       |               |         |         |         |         |  |  |
|          | GPIO26_SE                                   | ΞL         |                                      | 2 (SMBus 2         | clock pin)    |         |         |         |         |  |  |
|          |                                             |            |                                      | 026 function       |               |         |         |         |         |  |  |
|          | GPIO25_SE                                   | <u>-</u> L |                                      | •                  | er FAN 2 inp  | ut)     |         |         |         |  |  |
|          |                                             | _,         |                                      | 025 function       |               | N       |         |         |         |  |  |
|          | GPIO24_SEL 1: FAN1 (Tachometer FAN 1 input) |            |                                      |                    |               |         |         |         |         |  |  |

0: GPIO24 function



#### 9.1.18 GPIO E Input Register (GPIOEIN)<sup>1</sup>

| Location |       | 7             | 6             | 5             | 4             | 3             | 2             | 1             | 0             |
|----------|-------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| 7FA2H    | Read  | GPIO39_<br>IN | GPIO38_<br>IN | GPIO37_<br>IN | GPIO36_<br>IN | GPIO35_<br>IN | GPIO34_<br>IN | GPIO33_<br>IN | GPIO32_<br>IN |
|          | Write | -             | -             | -             | -             | -             | -             | -             | -             |
|          | Reset | GPIO39_<br>IN | GPIO38_<br>IN | GPIO37_<br>IN | GPIO36_<br>IN | GPIO35_<br>IN | GPIO34_<br>IN | GPIO33_<br>IN | GPIO32_<br>IN |

1. When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

#### Symbol

Function

GPIO[39:32]\_IN

Not implemented

\_IN When read, returns the status of the pin.

#### 9.1.19 GPIO E Output Register (GPIOEOUT)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO39_ | GPIO38_ | GPIO37_ | GPIO36_ | GPIO35_ | GPIO34_ | GPIO33_ | GPIO32_ |
| 7FA1H    | Write | OUT     |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

Symbol GPIO[39:32]\_OUT

#### Function

When written to, output data is updated. When read, returns previously written data.

## 9.1.20 GPIO E Function Select Register (GPIOESEL)

| Location |                    | 7       | 6                                                               | 5             | 4             | 3             | 2       | 1       | 0       |  |
|----------|--------------------|---------|-----------------------------------------------------------------|---------------|---------------|---------------|---------|---------|---------|--|
|          | Read               | GPIO39_ | GPIO38_                                                         | GPIO37_       | GPIO36_       | GPIO35_       | GPIO34_ | GPIO33_ | GPIO32_ |  |
| 7FDEH    | Write              | SEL     | SEL                                                             | SEL           | SEL           | SEL           | SEL     | SEL     | SEL     |  |
|          | Reset              | 1       | 1                                                               | 0             | 0             | 0             | 0       | 0       | 0       |  |
|          | Symbol             |         | Functio                                                         | n             |               |               |         |         |         |  |
|          | GPIO39_SE          | ΞL      |                                                                 |               | on (PCI Clock | k Control sig | nal)    |         |         |  |
|          |                    |         | 0: GPIO39 function                                              |               |               |               |         |         |         |  |
|          | GPIO38_SE          | EL      |                                                                 |               | PC power do   | wn signal)    |         |         |         |  |
|          |                    |         | 0: GPIO38 function                                              |               |               |               |         |         |         |  |
|          | GPIO37_SE          | ΞL      | 1: KSO15 output (Keyboard scan output 15)<br>0: GPIO37 function |               |               |               |         |         |         |  |
|          |                    | -1      |                                                                 |               |               |               |         |         |         |  |
|          | GPIO36_SE          | ΞL      | 1: KSO14 output (Keyboard scan output 14)<br>0: GPIO36 function |               |               |               |         |         |         |  |
|          | GPIO35 SE          | =1      |                                                                 |               | eyboard sca   | n output 13)  |         |         |         |  |
|          | GI 1000_01         |         |                                                                 | 035 function  | cybourd bour  | nouiput ioj   |         |         |         |  |
|          | GPIO34 SE          | EL      | 1: KSO                                                          | 12 output (Ke | eyboard sca   | n output 12)  |         |         |         |  |
|          | _                  |         |                                                                 | )34 function  |               | . ,           |         |         |         |  |
|          | GPIO33_SE          | EL      | 1: PSD/                                                         | nannel 2 data | a pin)        |               |         |         |         |  |
|          |                    |         | 0: GPIC                                                         | 033 function  |               |               |         |         |         |  |
|          | GPIO32_SE          | EL      |                                                                 |               | nannel 2 cloc | x pin)        |         |         |         |  |
|          | 0: GPIO32 function |         |                                                                 |               |               |               |         |         |         |  |



## 9.1.21 GPIO F Direction Register (GPIOFDIR)

| Location   |            | 7           | 6                          | 5             | 4       | 3 | 2       | 1       | 0 |  |  |
|------------|------------|-------------|----------------------------|---------------|---------|---|---------|---------|---|--|--|
|            | Read       | GPIO47_     | GPIO46_                    | -             | -       | - | GPIO42_ | GPIO41_ | - |  |  |
| 7FA3H      | Write      | DIR         | DIR                        |               |         |   | DIR     | DIR     |   |  |  |
|            | Reset      | 0           | 0                          | Х             | Х       | Х | 0       | 0       | Х |  |  |
|            | Symbol     |             | Functio                    | n             |         |   |         |         |   |  |  |
|            | -          |             | Not implemented            |               |         |   |         |         |   |  |  |
|            | Х          |             | Not defined                |               |         |   |         |         |   |  |  |
|            | GPIO[47:46 | ]_DIR       | GPIO direction control bit |               |         |   |         |         |   |  |  |
|            |            |             | 1: Outp                    |               |         |   |         |         |   |  |  |
|            |            |             | 0: Input                   |               |         |   |         |         |   |  |  |
|            | GPIO[42:41 | ]_DIR       |                            | irection cont | rol bit |   |         |         |   |  |  |
|            |            |             | 1: Output                  |               |         |   |         |         |   |  |  |
|            |            |             | 0: Input                   |               |         |   |         |         |   |  |  |
| 0 1 22 CDM |            | Rogistor (G |                            |               |         |   |         |         |   |  |  |

#### 9.1.22 GPIO F Input Register (GPIOFIN)<sup>1</sup>

| Location |       | 7             | 6             | 5             | 4             | 3             | 2             | 1             | 0             |
|----------|-------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| 7FA5H    | Read  | GPIO47_<br>IN | GPIO46_<br>IN | GPIO45_<br>IN | GPIO44_<br>IN | GPIO43_<br>IN | GPIO42_<br>IN | GPIO41_<br>IN | GPIO40_<br>IN |
|          | Write | -             | -             | -             | -             | -             | -             | -             | -             |
|          | Reset | GPIO47_<br>IN | GPIO46_<br>IN | GPIO45_<br>IN | GPIO44_<br>IN | GPIO43_<br>IN | GPIO42_<br>IN | GPIO41_<br>IN | GPIO40_<br>IN |

1. When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

Symbol

## Function

GPIO[47:40]\_IN

Not implemented

# When read, returns the status of the pin.

### 9.1.23 GPIO F Output Register (GPIOFOUT)

| Location |       | 7       | 6       | 5 | 4 | 3 | 2       | 1       | 0       |
|----------|-------|---------|---------|---|---|---|---------|---------|---------|
|          | Read  | GPIO47_ | GPIO46_ | - | - | - | GPIO42_ | GPIO41_ | GPIO40_ |
| 7FA4H    | Write | OUT     | OUT     |   |   |   | OUT     | OUT     | OUT     |
|          | Reset | 1       | 1       | Х | Х | Х | 1       | 1       | 1       |

Symbol Х

#### Function

Not implemented Not defined GPIO[47:40]\_OUT When written to, output data is updated. When read, returns previously written data.



| Location |           | 7       | 6                                               | 5            | 4              | 3      | 2 | 1 | 0       |  |  |
|----------|-----------|---------|-------------------------------------------------|--------------|----------------|--------|---|---|---------|--|--|
|          | Read      | GPIO47_ | GPIO46_                                         | GPIO45_      | -              | -      | - | - | GPIO40_ |  |  |
| 7FA6H    | Write     | SEL     | SEL                                             | SEL          |                |        |   |   | SEL     |  |  |
|          | Reset     | 0       | 0                                               | 0            | Х              | Х      | Х | Х | 0       |  |  |
|          | Symbol    |         | Functio                                         | on           |                |        |   |   |         |  |  |
|          | -         |         | Not imp                                         | lemented     |                |        |   |   |         |  |  |
|          | Х         |         | Not def                                         | ned          |                |        |   |   |         |  |  |
|          | GPIO47_SE | EL      | 1: T2 (Timer2 counter input or output)          |              |                |        |   |   |         |  |  |
|          |           |         | 0: GPIO47 function                              |              |                |        |   |   |         |  |  |
|          | GPIO46_SE | EL      | 1: T1 (T                                        | imer1 count  | er input or ou | utput) |   |   |         |  |  |
|          |           |         | 0: GPIC                                         | 046 function |                |        |   |   |         |  |  |
|          | GPIO45_SE | EL      | 1: T0 (T                                        | imer0 count  | er input)      |        |   |   |         |  |  |
|          |           |         | 0: GPI45 function                               |              |                |        |   |   |         |  |  |
|          | GPIO40_SE | EL      | 1: EC1_SCI (ACPI EC channel 1 interrupt output) |              |                |        |   |   |         |  |  |
|          |           |         | 0: GPIO40 function                              |              |                |        |   |   |         |  |  |

## 9.1.24 GPIO F Function Select Register (GPIOFSEL)

#### 9.1.25 GPIO G Direction Register (GPIOGDIR)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO55_ | GPIO54_ | GPIO53_ | GPIO52_ | GPIO51_ | GPIO50_ | GPIO49_ | GPIO48_ |
| 7F39H    | Write | DIR     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol GPIO[55:48]\_DIR Function GPIO direction control bit 1: Output

0: Input

## 9.1.26 GPIO G Input Register (GPIOGIN)<sup>1</sup>

| Location |       | 7             | 6             | 5             | 4             | 3             | 2             | 1             | 0             |
|----------|-------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| 7F3BH    | Read  | GPIO55_<br>IN | GPIO54_<br>IN | GPIO53_<br>IN | GPIO52_<br>IN | GPIO51_<br>IN | GPIO50_<br>IN | GPIO49_<br>IN | GPIO48_<br>IN |
|          | Write | -             | -             | -             | -             | -             | -             | -             | -             |
|          | Reset | GPIO55_       | GPIO54_       | GPIO53_       | GPIO52_       | GPIO51_       | GPIO50_       | GPIO49_       | GPIO48_       |
|          |       | IN            |

1. When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

Symbol

#### Function

GPIO[55:48]\_IN

Not implemented

10[55:48]\_111

When read, returns the status of the pin.



## 9.1.27 GPIO G Output Register (GPIOGOUT)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO55_ | GPIO54_ | GPIO53_ | GPIO52_ | GPIO51_ | GPIO50_ | GPIO49_ | GPIO48_ |
| 7F3AH    | Write | OUT     |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

**Symbol** GPIO[55:48]\_OUT Function

When written to, output data is updated. When read, returns previously written data.

#### 9.1.28 GPIO G Function Select Register (GPIOGSEL)

| Location |               | 7  | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 5                            | 4              | 3              | 2              | 1              | 0              |  |  |
|----------|---------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|----------------|----------------|----------------|----------------|----------------|--|--|
| 7F3CH    | Read<br>Write | -  | GPIO54_<br>SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | GPIO53_<br>SEL               | GPIO52_<br>SEL | GPIO51_<br>SEL | GPIO50_<br>SEL | GPIO49_<br>SEL | GPIO48_<br>SEL |  |  |
|          | Reset         | X  | 0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 |                              |                |                |                |                |                |  |  |
|          | Symbol        |    | Functio                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | on                           |                |                |                |                |                |  |  |
|          | -             |    | Not imp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | lemented                     |                |                |                |                |                |  |  |
|          | Х             |    | Not defi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ned                          |                |                |                |                |                |  |  |
|          | GPIO54_SE     | ΞL | 1: SCL1 (SMBus 1 clock)/TXD (UART transmit output) selected by UART_SM bit 0: GPIO54 function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                              |                |                |                |                |                |  |  |
|          | GPIO53_SE     | ΞL | 1: SDA1 (SMBus 1 data)/RXD (UART receive input) selected by UART_SM b<br>0: GPI053 function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                              |                |                |                |                |                |  |  |
|          | GPIO52_SE     | EL |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ) (SMBus 0<br>)52 function   | clock pin)     |                |                |                |                |  |  |
|          | GPIO51_SE     | EL |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ) (SMBus 0<br>)51 function   | data pin)      |                |                |                |                |  |  |
|          | GPIO50_SE     | EL |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | CLKOUT (32)<br>050 function. | .768KHz clo    | ck signal out  | put)           |                |                |  |  |
|          | GPIO49_SE     | EL | 1: CLKOUT (8051 core clock output)<br>0: GPIO49 function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                              |                |                |                |                |                |  |  |
|          | GPIO48_SE     | ΞL | 1: WDOGOUT (Watchdog timer output)<br>0: GPIO48 function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                              |                |                |                |                |                |  |  |

#### 9.1.29 GPIO H Direction Register (GPIOHDIR)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO63_ | GPIO62_ | GPIO61_ | GPIO60_ | GPIO59_ | GPIO58_ | GPIO57_ | GPIO56_ |
| 7FE0H    | Write | DIR     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol GPIO[63:56]\_DIR

## Function

GPIO direction control bit 1: Output 0: Input



#### 9.1.30 GPIO H Input Register (GPIOHIN)<sup>1</sup>

| Location |       | 7             | 6             | 5            | 4             | 3             | 2             | 1             | 0             |
|----------|-------|---------------|---------------|--------------|---------------|---------------|---------------|---------------|---------------|
| 7FE2H    | Read  | GPIO63_<br>IN | GPIO62_<br>IN | GPIO61_<br>N | GPIO60_<br>IN | GPIO59_<br>IN | GPIO58_<br>IN | GPIO57_<br>IN | GPIO56_<br>IN |
|          | Write | -             | -             | -            | -             | -             | -             | -             | -             |
|          | Reset | GPIO63_<br>IN | GPIO62_<br>IN | GPIO61_<br>N | GPIO60_<br>IN | GPIO59_<br>IN | GPIO58_<br>IN | GPIO57_<br>IN | GPIO56_<br>IN |

1. When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

#### Symbol

## Function

GPIO[63:56]\_IN

Not implemented

N When read, returns the status of the pin.

#### 9.1.31 GPIO H Output Register (GPIOHOUT)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO63_ | GPIO62_ | GPIO61_ | GPIO60_ | GPIO59_ | GPIO58_ | GPIO57_ | GPIO56_ |
| 7FE1H    | Write | OUT     |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

Symbol

GPIO[63:56]\_OUT

When written to, output data is updated. When read, returns previously written data.

#### 9.1.32 GPIO HL Open-Drain/Push-Pull Section Register (GPIOHLOD)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO63_ | GPIO62_ | GPIO61_ | GPIO60_ | GPIO91_ | GPIO90_ | GPIO89_ | GPIO88_ |
| 7FABH    | Write | OD      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function

Function

| GPIO[63:60]_OD | GPIO output buffer configuration control bit |
|----------------|----------------------------------------------|
|                | 1: Open-Drain configuration                  |
|                | 0: Push-Pull configuration                   |
| GPIO[91:88]_OD | GPIO output buffer configuration control bit |
|                | 1: Open-Drain configuration                  |
|                | 0: Push-Pull configuration                   |

#### 9.1.33 GPIO I Direction Register (GPIOIDIR)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO71_ | GPIO70_ | GPIO69_ | GPIO68_ | GPIO67_ | GPIO66_ | GPIO65_ | GPIO64_ |
| 7FE3H    | Write | DIR     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

**Symbol** GPIO[71:64]\_DIR Function GPIO direction control bit 1: Output 0: Input



## 9.1.34 GPIO I Input Register (GPIOIIN)<sup>1</sup>

| Location |       | 7             | 6             | 5             | 4             | 3             | 2             | 1             | 0             |
|----------|-------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| 7FE5H    | Read  | GPIO71_<br>IN | GPIO70_<br>IN | GPIO69_<br>IN | GPIO68_<br>IN | GPIO67_<br>IN | GPIO66_<br>IN | GPIO65_<br>IN | GPIO64_<br>IN |
|          | Write | -             | -             | -             | -             | -             | -             | -             | -             |
|          | Reset | GPIO71_<br>IN | GPIO70_<br>IN | GPIO69_<br>IN | GPIO68_<br>IN | GPIO67_<br>IN | GPIO66_<br>IN | GPIO65_<br>IN | GPIO64_<br>IN |

1. When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

#### Symbol

Function

| -              | Not implemented                                                    |
|----------------|--------------------------------------------------------------------|
| GPIO[67:64]_IN | When read, returns the status of the pin.                          |
| GPIO[71:68]_IN | When read, returns the status of the pin in normal GPIO mode only. |

#### 9.1.35 GPIO I Output Register (GPIOIOUT)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO71_ | GPIO70_ | GPIO69_ | GPIO68_ | GPIO67_ | GPIO66_ | GPIO65_ | GPIO64_ |
| 7FE4H    | Write | OUT     |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

Symbol

GPIO[71:64]\_OUT

## Function

When written to, output data is updated. When read, returns previously written data

#### 9.1.36 GPIO I Function Select Register (GPIOISEL)

| Location |       | 7       | 6       | 5       | 4       | 3 | 2 | 1 | 0 |
|----------|-------|---------|---------|---------|---------|---|---|---|---|
|          | Read  | GPIO71_ | GPIO70_ | GPIO69_ | GPIO68_ | - | - | - | - |
| 7FF0H    | Write | SEL     | SEL     | SEL     | SEL     |   |   |   |   |
|          | Reset | 0       | 0       | 0       | 0       | Х | Х | Х | Х |

| Symbol     | Function                                                                     |
|------------|------------------------------------------------------------------------------|
| -          | Not implemented                                                              |
| Х          | Not Defined                                                                  |
| GPIO71_SEL | 1: DAC3 (Digital to Analog converter channel 3 output)<br>0: GPIO71 function |
| GPIO70_SEL | 1: DAC2 (Digital to Analog converter channel 2 output)<br>0: GPIO70 function |
| GPIO69_SEL | 1: DAC1 (Digital to Analog converter channel 1 output)<br>0: GPIO71 function |
| GPIO68_SEL | 1: DAC0 (Digital to Analog converter channel 0 output)<br>0: GPIO70 function |



#### 9.1.37 GPIO I Open-Drain/Push-Pull Section Register (GPIOIOD)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO71_ | GPIO70_ | GPIO69_ | GPIO68_ | GPIO67_ | GPIO66_ | GPIO65_ | GPIO64_ |
| 7FACH    | Write | OD      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol GPIO[71:64]\_OD

#### Function

GPIO output buffer configuration control bit. 1: Open-Drain configuration

0: Push-Pull configuration

#### 9.1.38 GPIO J Direction Register (GPIOJDIR)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO79_ | GPIO78_ | GPIO77_ | GPIO76_ | GPIO75_ | GPIO74_ | GPIO73_ | GPIO72_ |
| 7FE6H    | Write | DIR     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol GPIO[79:72]\_DIR

#### Function

GPIO direction control bit 1: Output 0: Input

### 9.1.39 GPIO J Input Register (GPIOJIN)<sup>1</sup>

| Location |       | 7             | 6             | 5             | 4             | 3             | 2             | 1             | 0             |
|----------|-------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| 7FE8H    | Read  | GPIO79_<br>IN | GPIO78_<br>IN | GPIO77_<br>IN | GPIO76_<br>IN | GPIO75_<br>IN | GPIO74_<br>IN | GPIO73_<br>IN | GPIO72_<br>IN |
|          | Write | -             | -             | -             | -             | -             | -             | -             | -             |
|          | Reset | GPIO79_<br>IN | GPIO78_<br>IN | GPIO77_<br>IN | GPIO76_<br>IN | GPIO75_<br>IN | GPIO74_<br>IN | GPIO73_<br>IN | GPIO72_<br>IN |

1. When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

Symbol

#### Function Not implemented

GPIO[79:72]\_IN

When read, returns the status of the pin in normal GPIO mode only.

#### 9.1.40 GPIO J Output Register (GPIOJOUT)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO79_ | GPIO78_ | GPIO77_ | GPIO76_ | GPIO75_ | GPIO74_ | GPIO73_ | GPIO72_ |
| 7FE7H    | Write | OUT     |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

Symbol

#### Function

GPIO[79:72]\_OUT

When written to, output data is updated. When read, returns previously written data.



## 9.1.41 GPIO J Function Select Register (GPIOJSEL)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO79_ | GPIO78_ | GPIO77_ | GPIO76_ | GPIO75_ | GPIO74_ | GPIO73_ | GPIO72_ |
| 7FF5H    | Write | SEL     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol GPIO[79:72]\_SEL

#### Function

1: ACH[0:7] Analog to Digital converter channel 0 to 7 0: GPIO[79:72] function

## 9.1.42 GPIO J Open-Drain/Push-Pull Section Register (GPIOJOD)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO79_ | GPIO78_ | GPIO77_ | GPIO76_ | GPIO75_ | GPIO74_ | GPIO73_ | GPIO72_ |
| 7FADH    | Write | OD      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol GPIO[79:72]\_OD

#### Function

GPIO output buffer configuration control bit 1: Open-Drain configuration 0: Push-Pull configuration

## 9.1.43 GPIO K Direction Register (GPIOKDIR)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO87_ | GPIO86_ | GPIO85_ | GPIO84_ | GPIO83_ | GPIO82_ | GPIO81_ | GPIO80_ |
| 7FE9H    | Write | DIR     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol GPIO[87:80]\_DIR

#### Function

GPIO direction control bit 1: Output

0: Input

#### 9.1.44 GPIO K Input Register (GPIOKIN)<sup>1</sup>

| Location |       | 7             | 6             | 5             | 4             | 3             | 2             | 1             | 0             |
|----------|-------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| 7FEBH    | Read  | GPIO87_<br>IN | GPIO86_<br>IN | GPIO85_<br>IN | GPIO84_<br>IN | GPIO83_<br>IN | GPIO82_<br>IN | GPIO81_<br>IN | GPIO80_<br>IN |
|          | Write | -             | -             | -             | -             | -             | -             | -             | -             |
|          | Reset | GPIO87_       | GPIO86_       | GPIO85_       | GPIO84_       | GPIO83_       | GPIO82_       | GPIO81_       | GPIO80_       |
|          |       | IN            |

1. When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

Symbol

### Function

Not implemented

GPIO[87:80]\_IN

When read, returns the status of the pin.



#### 9.1.45 GPIO K Output Register (GPIOKOUT)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO87_ | GPIO86_ | GPIO85_ | GPIO84_ | GPIO83_ | GPIO82_ | GPIO81_ | GPIO80_ |
| 7FEAH    | Write | OUT     |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

Symbol GPIO[87:80]\_OUT **Function** When written to, output data is updated. When read, returns previously written data.

#### 9.1.46 GPIO K Pull-up Control Register (GPIOKPU)

| Location |       | 7 | 6 | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|---|---|--------|--------|--------|--------|--------|--------|
|          | Read  | - | - | GPIO85 | GPIO84 | GPIO83 | GPIO82 | GPIO81 | GPIO80 |
| 7FB7H    | Write |   |   | PU     | PU     | PU     | PU     | PU     | PU     |
|          | Reset | Х | Х | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol

Function

X GPIO[85:80]PU

# Not implemented Not defined

GPIO Internal Pull-up control bit 1: Enable Internal Pull-up 0: Disable Internal Pull-up

#### 9.1.47 GPIO L Direction Register (GPIOLDIR)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO95_ | GPIO94_ | GPIO93_ | GPIO92_ | GPIO91_ | GPIO90_ | GPIO89_ | GPIO88_ |
| 7FA7H    | Write | DIR     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

## Function

GPIO direction control bit

1: Output

0: Input

When GPIO[95:94]\_DIR=0, GPIO[95:94] are inputs with internal pull-ups enabled

#### 9.1.48 GPIO L Input Register (GPIOLIN)<sup>1</sup>

GPIO[95:88]\_DIR

| Location |       | 7             | 6             | 5             | 4             | 3             | 2             | 1             | 0             |
|----------|-------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| 7FA9H    | Read  | GPIO95_<br>IN | GPIO94_<br>IN | GPIO93_<br>IN | GPIO92_<br>IN | GPIO91_<br>IN | GPIO90_<br>IN | GPIO89_<br>IN | GPIO88_<br>IN |
|          | Write | -             | -             | -             | -             | -             | -             | -             | -             |
|          | Reset | GPIO95_<br>IN | GPIO94_<br>IN | GPIO93_<br>IN | GPIO92_<br>IN | GPIO91_<br>IN | GPIO90_<br>IN | GPIO89_<br>IN | GPIO88_<br>IN |

1. When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

#### Symbol

## Function

Not implemented

GPIO[95:88]\_IN

When read, returns the status of the pin.



## 9.1.49 GPIO L Output Register (GPIOLOUT)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO95_ | GPIO94_ | GPIO93_ | GPIO92_ | GPIO91_ | GPIO90_ | GPIO89_ | GPIO88_ |
| 7FA8H    | Write | OUT     |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

Symbol GPIO[95:88] OUT

#### Function

When written to, output data is updated. When read, returns previously written data.

#### 9.1.50 GPIO M Pullup Control Register (GPIOMPU)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO103 | GPIO102 | GPIO101 | GPIO100 | GPIO99_ | GPIO98_ | GPIO97_ | GPIO96_ |
| 7F5BH    | Write | _PU     | _PU     | _PU     | _PU     | PU      | PU      | PU      | PU      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function

GPIO[103:96]\_PU

GPIO Internal Pullup control bit 1: Disable Internal Pullup 0: Enable Internal Pullup

#### 9.1.51 GPIO M Input Register (GPIOMIN)<sup>1</sup>

| Location |       | 7              | 6              | 5              | 4              | 3             | 2             | 1             | 0             |
|----------|-------|----------------|----------------|----------------|----------------|---------------|---------------|---------------|---------------|
| 7F6BH    | Read  | GPIO103_<br>IN | GPIO102_<br>IN | GPIO101_<br>IN | GPIO100_<br>IN | GPIO99_<br>IN | GPIO98_<br>IN | GPIO97_<br>IN | GPIO96_<br>IN |
|          | Write | -              | -              | -              | -              | -             | -             | -             | -             |
|          | Reset | GPIO103_<br>IN | GPIO102_<br>IN | GPIO101_<br>IN | GPIO100_<br>IN | GPIO99_<br>IN | GPIO98_<br>IN | GPIO97_<br>IN | GPIO96_<br>IN |

1. When using an open drain pin as an input, output data must be specified as '1''1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

Symbol

### Function

-GPIO[103:96]\_IN Not implemented When read, returns the status of the pin.

## 9.1.52 GPIO M Output Register (GPIOMOUT)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO103 | GPIO102 | GPIO101 | GPIO100 | GPIO99_ | GPIO98_ | GPIO97_ | GPIO96_ |
| 7F30H    | Write | _OUT    | _OUT    | _OUT    | _OUT    | OUT     | OUT     | OUT     | OUT     |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

Symbol GPIO[103:96]\_OUT Function

When written to, output data is updated (see Table 9-2 below). When read, returns previously written data.



#### 9.1.53 GPIO M Open-Drain/Push-Pull Section Register (GPIOMOD)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO103 | GPIO102 | GPIO101 | GPIO100 | GPIO99_ | GPIO98_ | GPIO97_ | GPIO96_ |
| 7FF6H    | Write | _OD     | _OD     | _OD     | _OD     | OD      | OD      | OD      | OD      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol GPIO[103:96]\_OD

GPIO output buffer configuration control bit (see Table 9-2 below)

#### 9.1.54 GPIO N Pullup Control Register (GPIONPU)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO111 | GPIO110 | GPIO109 | GPIO108 | GPIO107 | GPIO106 | GPIO105 | GPIO104 |
| 7F83H    | Write | _PU     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

GPIO[111:104]\_PU

Function

Function

GPIO Internal Pullup control bit

1: Disable Internal Pullup

0: Enable Internal Pullup

#### 9.1.55 GPIO N Input Register (GPIONIN)<sup>1</sup>

| Location |       | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              |
|----------|-------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 7F84H    | Read  | GPIO111<br>_IN | GPIO110<br>_IN | GPIO109<br>_IN | GPIO108<br>_IN | GPIO107<br>_IN | GPIO106<br>_IN | GPIO105<br>_IN | GPIO104<br>_IN |
|          | Write | -              | -              | -              | -              | -              | -              | -              | -              |
|          | Reset | GPIO111<br>IN  | GPIO110<br>_IN | GPIO109<br>IN  | GPIO108<br>IN  | GPIO107<br>_IN | GPIO106<br>IN  | GPIO105<br>_IN | GPIO104<br>_IN |

1. When using an open drain pin as an input, output data must be specified as '1'. However, specifying output data as '0' when using an open drain pin as an input will damage the part.

Symbol

## Function

Not implemented

GPIO[111:104]\_IN When read, returns the status of the pin.

#### 9.1.56 GPIO N Output Register (GPIONOUT)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO111 | GPIO110 | GPIO109 | GPIO108 | GPIO107 | GPIO106 | GPIO105 | GPIO104 |
| 7F82H    | Write | _OUT    |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

Symbol GPIO[111:104] OUT

#### Function

When written to, output data is updated (see Table 9-2). When read, returns previously written data.



## 9.1.57 GPIO N Open-Drain/Push-Pull Section Register (GPIONOD)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | GPIO111 | GPIO110 | GPIO109 | GPIO108 | GPIO107 | GPIO106 | GPIO105 | GPIO104 |
| 7FFCH    | Write | _OD     |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol Function GPIO[111:104]\_OD

GPIO output buffer configuration control bit (see Table 9-2 below)

#### 9-2: GPIO96-GPIO111 Input/Output configuration control TABLE

| GPIOn_OD | GPIOn_OUT | Input/Output                  |
|----------|-----------|-------------------------------|
| 0        | 0         | Output '0'                    |
| 0        | 1         | Input / Output '1' open drain |
| 1        | 0         | Output '0'                    |
| 1        | 1         | Output '1' push pull          |

T9-2.0 1320



## **10.0 TIMERS/COUNTERS, WATCHDOG TIMER AND PWM**

## 10.1 Timers: T0, T1, T2

The SST79LF008 device has three 16-bit registers that can be used as either timers or event counters. The three timers/counters are denoted Timer 0 (T0), Timer 1 (T1), and Timer 2 (T2). Each is designated a pair of 8-bit registers in the Special Function Registers (SFRs). The pair of registers consists of a most significant (high) byte and least significant (low) byte. The respective registers are TL0, TH0, TL1, TH1, TL2, and TH2. See Table 10-4. Timer 2 also has the capture registers RCAP2L and RCAP2H. See Table 10-4.

## **10.2 Timer Operations**

Refer to Section 10.3 for full description of the TCON, TMOD, T2CON and T2MOD registers that control timer operations.

#### 10.2.1 Timer 1 and Timer 0

Timer 1 and Timer 0 operations are controlled by TMOD and TCON registers. Each timer can be configured to operate either as a timer or event counter depending on the value of the bits C/T#\_T1 and C/T\_/T0 in TMOD register. The clock source for timer function is 8051 core clock CCLK divided by 12. The clock source for the event counter function is either the T1 or T0 input pin respectively, or crystal oscillator clock XCLK as selected by CLKCON register (active falling edge for any source). Both the T1 and T0 timers count up. Each timer can be turned ON by setting, or turned OFF by clearing, the TR1/TR0 bit in TCON register.

There are four operating modes available in either timer or counter operations. In Modes 0, 1 and 2 both T0 and T1 operate similarly. In Mode 3, T0 and T1 operations are dif-

 TABLE
 10-1: Timer 0 Operating Modes

ferent. Table 10-1 and Table 10-2 provide the examples of TMOD values to be used to select operation modes for timers T1 and T0.

#### 10.2.1.1 Mode 0

In Mode 0 each timer is configured as a 13-bit timer, which includes 8-bit counter (TH1/TH0) and a 5-bit prescaler (lower 5 bits of TL1/TL0). As the count overflows from all 1s to all 0s, the counter continues to count, and the respective timer overflow flag TF1/TF0 is set.

#### 10.2.1.2 Mode 1

Mode 1 is similar to Mode 0, with the exception that each timer uses full 16-bit counter. The clock is applied to the combined high and low timer registers TH1:TL1/TH0:TL0.

#### 10.2.1.3 Mode 2

In Mode 2 each timer is configured as an 8-bit counter with automatic reload. Timer 1 uses TL1 register as a counter; when overflow occurs, bit TF1 is set, and TL1 is reloaded with the contents of register TH1. Timer 0 uses TL0 register as a counter; when overflow occurs, bit TF0 is set, and TL0 is reloaded with the contents of register TH0. The reload does not modify TH1/TH0 value.

#### 10.2.1.4 Mode 3

Timer 1 in Mode 3 is halted and holds its count. Timer 0 in Mode 3 is divided into two separate 8-bit counters TL0 and TH0. Timer 0 control bits: C/T#\_T0, TR0, and TF0 are dedicated to TL0 operations only. Timer 1 control bits: TR1 and TF1 are dedicated to TH0 operations only, and TH0 is forced into timer mode which uses CCLK divided by 12 as a clock source.

|                 | Mode | Function                                                           | TMOD <sup>1</sup> |
|-----------------|------|--------------------------------------------------------------------|-------------------|
| Used as Timer   | 0    | 13-bit Timer                                                       | 00H               |
|                 | 1    | 16-bit Timer                                                       | 01H               |
|                 | 2    | 8-bit Auto-Reload                                                  | 02H               |
|                 | 3    | Two 8-bit Timers                                                   | 03H               |
| Used as Counter | 0    | 13-bit Counter<br>8-bit Counter TH0 with TL0 as 5-bit<br>prescaler | 04H               |
|                 | 1    | 16-bit Counter                                                     | 05H               |
|                 | 2    | 8-bit Auto-Reload                                                  | 06H               |
|                 | 3    | Two 8-bit Counters                                                 | 07H               |

1. The Timer is turned ON/OFF by setting/clearing bit TR0.

T10-1.0 1320



| TABLE | 10-2: | Timer 1 | Operating | Modes |
|-------|-------|---------|-----------|-------|
|-------|-------|---------|-----------|-------|

|                 | Mode | Function                                                        | TMOD <sup>1</sup> |
|-----------------|------|-----------------------------------------------------------------|-------------------|
| Used as Timer   | 0    | 13-bit Timer                                                    | 00H               |
|                 | 1    | 16-bit Timer                                                    | 10H               |
|                 | 2    | 8-bit Auto-Reload                                               | 20H               |
|                 | 3    | Stopped                                                         | 30H               |
| Used as Counter | 0    | 13-bit Counter<br>8-bit Counter TH1 with TL1 as 5-bit prescaler | 40H               |
|                 | 1    | 16-bit Counter                                                  | 50H               |
|                 | 2    | 8-bit Auto-Reload                                               | 60H               |
|                 | 3    | Not Available                                                   | -                 |
|                 |      | •                                                               | T10-2.0 132       |

1. The Timer is turned ON/OFF by setting/clearing bit TR1.

#### 10.2.2 Timer 2

Similar to Timer 1 and 0, Timer 2 can operate either as a timer or as an event counter, depending on the value of bit C/T2# in T2CON register. Timer 2 has three operating modes: capture, auto-reload, and baud rate generator. Refer to Table 10-3 examples of the respective settings.

#### 10.2.2.1 16-bit Timer/Counter Capture Mode

In the capture mode, the EXEN2 bit in T2CON selects one of two options. If EXEN2 bit is cleared to 0, then Timer 2 is a 16-bit timer/counter. When the timer/counter overflow occurs, Timer 2 overflow bit TF2 will be set. If EXEN2 bit is set to 1, then Timer 2 operates the same way, but in addition a falling edge on the external input T2EX causes the current value in the Timer 2 registers TL2 and TH2 to be captured into the RCAP2L and RCAP2H registers respectively. The T2EX falling edge also sets the EXF2 bit in T2CON. Either TF2 or EXF2 flags can generate Timer 2 interrupt to 8051.

| 10.2.2.2 16-bit Timer/Counter Auto-reload Mode | Э |
|------------------------------------------------|---|
|------------------------------------------------|---|

In the auto-reload mode, the EXEN2 bit in T2CON also selects one of two options. If EXEN2 is cleared to 0, then when the 16-bit timer/counter overflow occurs. TF2 bit is set, and Timer 2 registers are reloaded with the contents of the RCAP2L and RCAP2H registers. If EXEN2 is set to 1, then Timer 2 operates the same way as above, but, in addition a falling edge on the external input, T2EX also triggers the counter reload and sets EXF2 bit. Either TF2 or EXF2 flags can generate Timer 2 interrupt to 8051.

#### 10.2.2.3 Baud Rate Generator Mode

When RCLK or TCLK bit is set to 1, T2 output signal determines UART baud rates for receive and/or transmit as described in Section 11.0. This mode is similar to autoreload mode with the following exceptions: TF2 flag is not set on overflow, and T2EX falling edge does not cause a reload.

|                 |                                             | T20                           | CON <sup>1</sup>              |
|-----------------|---------------------------------------------|-------------------------------|-------------------------------|
|                 | Mode                                        | Internal Control <sup>2</sup> | External Control <sup>3</sup> |
| Used as Timer   | 16-bit Auto Reload                          | 00H                           | 08H                           |
|                 | 16-bit Capture                              | 01H                           | 09H                           |
|                 | Baud rate generator Receive<br>and Transmit | 30H                           | 38H                           |
|                 | Receive only                                | 20H                           | 28H                           |
|                 | Transmit only                               | 10H                           | 18H                           |
| Used as Counter | 16-bit Auto Reload                          | 02H                           | 0AH                           |
|                 | 16-bit Capture                              | 03H                           | 0BH                           |

## TABLE10-3: Timer 2 Operating Modes

1. The Timer is turned ON/OFF by setting/clearing bit TR2.

2. Capture/Reload occurs only on timer or counter overflow.

3. Capture/Reload occurs on timer or counter overflow and a 1 to 0 transition on T2EX pin except when Timer 2 is used in the baud rate generating mode. The GPIO15 pin must be set as T2EX.

T10-3 0 1320



## 10.3 Timers/Counters SFRs

## TABLE 10-4: Timer/Counters SFRs

|                    | Direct                       |         | Direct Symbol                          |          |      |      |           |       |                                           |             | RESET        |
|--------------------|------------------------------|---------|----------------------------------------|----------|------|------|-----------|-------|-------------------------------------------|-------------|--------------|
| Symbol             | Description                  | Address | MSB                                    |          |      |      |           |       |                                           | LSB         | Value        |
| TMOD               | Timer/Counter Mode           | 89H     | 89H Timer 1 Control bits Timer 0 Contr |          |      |      |           |       | Timer 1 Control bits Timer 0 Control bits |             | 00H          |
|                    | Control                      |         | GATE                                   | C/       | M1_  | M0_  | GATE      | C/    | M1_                                       | M0_         |              |
|                    |                              |         | _T1                                    | T#_T1    | T1   | T1   | _T0       | T#_T0 | T0                                        | T0          |              |
| TCON <sup>1</sup>  | Timer/Counter<br>Control     | 88H     | TF1                                    | TR1      | TF0  | TR0  | IE1       | IT1   | IE0                                       | ITO         | 00H          |
| TH0                | Timer 0 MSB                  | 8CH     |                                        | TH0[7:0] |      |      |           | 00H   |                                           |             |              |
| TL0                | Timer 0 LSB                  | 8AH     |                                        | TL0[7:0] |      |      |           |       |                                           | 00H         |              |
| TH1                | Timer 1 MSB                  | 8DH     | TH1[7:0]                               |          |      |      |           |       | 00H                                       |             |              |
| TL1                | Timer 1 LSB                  | 8BH     |                                        | TL1[7:0] |      |      |           |       |                                           | 00H         |              |
| T2CON <sup>1</sup> | Timer / Counter 2<br>Control | C8H     | TF2                                    | EXF2     | RCLK | TCLK | EXEN<br>2 | TR2   | C/T2#                                     | CP/<br>RL2# | 00H          |
| T2MOD#             | Timer 2<br>Mode Control      | C9H     | -                                      | -        | -    | -    | -         | T1OE  | T2OE                                      | DCEN        | ХОН          |
| TH2                | Timer 2 MSB                  | CDH     | TH2[7:0]                               |          |      |      | 00H       |       |                                           |             |              |
| TL2                | Timer 2 LSB                  | CCH     | TL2[7:0]                               |          |      |      |           | 00H   |                                           |             |              |
| RCAP2H             | Timer 2 Capture<br>MSB       | СВН     | RCAP2H[7:0]                            |          |      |      |           | 00H   |                                           |             |              |
| RCAP2L             | Timer 2 Capture LSB          | CAH     |                                        |          |      | RCAP | 2L[7:0]   |       |                                           |             | 00H          |
|                    |                              |         |                                        |          |      |      |           |       |                                           |             | T10-4.0 1320 |

1. Bit x Addressable SFRs -8.0 555

T10-4.0 1320



## 10.3.1 Timer / Counter Control Register (TCON)

| Location |                                                                                                                                                                                                                                                                                 | 7   | 6                                                                                       | 5                                                                                                                                                                                                                                                                                | 4   | 3   | 2   | 1   | 0   |  |  |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-----|-----|-----|--|--|
|          | Read                                                                                                                                                                                                                                                                            | TF1 | TR1                                                                                     | TF0                                                                                                                                                                                                                                                                              | TR0 | IE1 | IT1 | IE0 | IT0 |  |  |
| 88H      | Write                                                                                                                                                                                                                                                                           |     |                                                                                         |                                                                                                                                                                                                                                                                                  |     | -   | -   | -   | -   |  |  |
|          | Reset                                                                                                                                                                                                                                                                           | 0   | 0                                                                                       | 0                                                                                                                                                                                                                                                                                | 0   | 0   | 0   | 0   | 0   |  |  |
|          | Symbol     Function       -     Not implemented       TF1     Timer 1 overflow flag. Set by hardware on Timer/Counter overflow. Cleared to hardware when processor vectors to interrupt service routine, or it can be cleared being the service routine of the service routine. |     |                                                                                         |                                                                                                                                                                                                                                                                                  |     |     |     |     | -   |  |  |
|          | TR1<br>TF0                                                                                                                                                                                                                                                                      |     | Timer 1<br>Timer 0<br>hardwa                                                            | in software.<br>Timer 1 run control bit. Set/cleared by software to turn on/off Timer/Counter<br>Timer 0 overflow flag. Set by hardware on Timer/Counter overflow. Cleared by<br>hardware when processor vectors to interrupt service routine, or can be cleared in<br>software. |     |     |     |     |     |  |  |
|          | TR0<br>IE1                                                                                                                                                                                                                                                                      |     | Interrup                                                                                | Timer 0 run control bit. Set/cleared by software to turn on/off Timer/Counter<br>Interrupt INT1 request flag<br>This is read only bit equal to the INT1 signal (see Figure 8-1 for INT1 signal<br>sources)                                                                       |     |     |     |     |     |  |  |
|          | IT1                                                                                                                                                                                                                                                                             |     | Interrup                                                                                | Interrupt 1 type control bit. Always cleared.<br>0: INT1 is a level triggered interrupt                                                                                                                                                                                          |     |     |     |     |     |  |  |
|          | IE0                                                                                                                                                                                                                                                                             |     | Interrup<br>This is a                                                                   | Interrupt INT0 request flag<br>This is a read only bit equal to the INT0 signal (see Figure 8-1 for INT0 signal<br>sources)                                                                                                                                                      |     |     |     |     |     |  |  |
|          | IT0                                                                                                                                                                                                                                                                             |     | Interrupt 0 type control bit. Always cleared.<br>0: INT0 is a level triggered interrupt |                                                                                                                                                                                                                                                                                  |     |     |     |     |     |  |  |

| 10.3.2 Timer / Counter Mode Register (TMOD) |
|---------------------------------------------|
|---------------------------------------------|

| Location |       | 7       | 6       | 5     | 4     | 3       | 2       | 1     | 0     |
|----------|-------|---------|---------|-------|-------|---------|---------|-------|-------|
|          | Read  | GATE_T1 | C/T#_T1 | M1_T1 | M0_T1 | GATE_T0 | C/T#_T0 | M1_T0 | M0_T0 |
| 89H      | Write | -       |         |       |       | -       |         |       |       |
|          | Reset | 0       | 0       | 0     | 0     | 0       | 0       | 0     | 0     |

| Symbol  | Function                                                                |
|---------|-------------------------------------------------------------------------|
| -       | Not implemented                                                         |
| GATE T1 | Timer 1 gating control bit. Always cleared.                             |
|         | 0: Gate function is disabled and Timer 1 is controlled by TR1 bit only. |
| C/T#_T1 | Timer or Counter Selector bit (Timer 1).                                |
|         | 1: Counter operation (input clock is selected by CLKCON register).      |
|         | 0: Timer operation (input clock frequency is FCCLK/12).                 |
| M1_T1   | Mode bit 1 for T1.                                                      |
| M0_T1   | Mode bit 0 for T1.                                                      |
| GATE_T0 | Timer 0 gating control bit. Always cleared.                             |
|         | 0: Gate function is disabled and Timer 0 is controlled by TR0 bit only. |
| C/T#_T0 | Timer or Counter Selector bit (Timer 0)                                 |
|         | 1: Counter operation (input clock is selected by CLKCON register).      |
|         | 0: Timer operation (input clock frequency is FCCLK/12).                 |
| M1_T0   | Mode bit 1 for T0.                                                      |
| M0_T0   | Mode bit 0 for T0.                                                      |
|         |                                                                         |



| M1_Tn <sup>1</sup> | M0_Tn <sup>1</sup> | Mode   | Operating mode                                                                                               |
|--------------------|--------------------|--------|--------------------------------------------------------------------------------------------------------------|
| 0                  | 0                  | 0      | 13-bit Timer Mode.                                                                                           |
|                    |                    |        | 8-bit Timer/Counter THn with TLn as 5-bit prescaler.                                                         |
| 0                  | 1                  | 1      | 16-bit Timer Mode.                                                                                           |
|                    |                    |        | THn and TLn are cascaded into 16-bit Timer/Counter with no prescaler.                                        |
| 1                  | 0                  | 2      | 8-bit Auto Reload Mode.                                                                                      |
|                    |                    |        | THn holds a value, which has to be reloaded into 8-bit auto-reload Timer/Counter TL1 each time it overflows. |
| 1                  | 1                  | 3 (T1) | Timer/Counter 1 is stopped.                                                                                  |
| 1                  | 1                  | 3 (T0) | TL0 is an 8-bit Timer/Counter controlled by the Timer 0 control bits.                                        |
|                    |                    |        | TH0 is an 8-bit Timer only controlled by Timer 1 control bits.                                               |

# TABLE 10-5: Timer Operating Mode as a Function of Mode Bits

1. n=0,1

T10-5.1320

# 10.3.3 Timer/Counter 2 Control Register (T2CON)

| Location |                                                                                                                                                                                                                                                                                                                                                                                                                                      | 7                                                                                                                                                                                 | 6                  | 5                                          | 4                             | 3                                                             | 2                              | 1                            | 0                        |  |  |  |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------------------------------|-------------------------------|---------------------------------------------------------------|--------------------------------|------------------------------|--------------------------|--|--|--|
|          | Read                                                                                                                                                                                                                                                                                                                                                                                                                                 | TF2                                                                                                                                                                               | EXF2               | RCLK                                       | TCLK                          | EXEN2                                                         | TR2                            | C/T2#                        | CP/RL2#                  |  |  |  |
| C8H      | Write                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                   |                    |                                            |                               |                                                               |                                |                              |                          |  |  |  |
|          | Reset                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                 | 0                  | 0                                          | 0                             | 0                                                             | 0                              | 0                            | 0                        |  |  |  |
|          | Symbol                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                   | Functio            | on                                         |                               |                                                               |                                |                              |                          |  |  |  |
|          | TF2                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                   | TF2 wil<br>clock o | l not be set in<br>utput mode (            | n baud rate g<br>when T20E    | mer 2 overflo<br>generator mo<br>= 1 and C/T2                 | ode (when R<br>2# = 0).        | CLK or TCL                   | $\dot{x} = 1$ ) and ir   |  |  |  |
|          | EXF2Timer 2 external flag set when either a capture or reload is caused by a falling edg<br>on T2EX and EXEN2 = 1, and must be cleared by software. When Timer 2<br>interrupt is enabled, EXF2 = 1 will cause the CPU to vector to the Timer 2 interrupt<br>routine. EXF2 does not cause an interrupt in up/down counter mode (DCEN = 1)<br>RCLKRCLKReceive clock flag. When set, causes the UART to use Timer 2 overflow pulses for |                                                                                                                                                                                   |                    |                                            |                               |                                                               |                                |                              |                          |  |  |  |
|          | RCLK                                                                                                                                                                                                                                                                                                                                                                                                                                 | Receive clock flag. When set, causes the UART to use Timer 2 overflow pulses its receive clock in modes 1 and 3. RCLK = 0 causes Timer 1 overflow to be us for the receive clock. |                    |                                            |                               |                                                               |                                |                              |                          |  |  |  |
|          | TCLK                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                   | transmi            | •                                          |                               | auses the UA<br>TCLK = 0 ca                                   |                                |                              |                          |  |  |  |
|          | EXEN2                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                   | as a res           | sult of a nega                             | ative transitio               | oit. When sel<br>n on T2EX if<br>r 2 to ignore                | Timer 2 is no                  | ot being use                 |                          |  |  |  |
|          | TR2<br>C/T2#                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                   | Timer c            | or counter se                              | lect (Timer 2                 | ,                                                             |                                | Ū                            | stops Timer              |  |  |  |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                   | 0: Interi          | nal timer inpu                             | ut clock frequ                | out pin falling<br>Jency is Fcc∟<br>when RCLK                 | к/12 when F                    | ICLK = 0 an                  | d TCLK = 0               |  |  |  |
|          | CP/RL2#                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                   | EXEN2<br>with ne   | = 1. When of gative transit 1, this bit is | cleared, auto<br>ions at T2E> | captures occ<br>-reloads occ<br>( when EXEI<br>the timer is t | ur either when $N2 = 1$ . When | en Timer 2 c<br>n either RCI | verflows or<br>_K = 1 or |  |  |  |



# 10.3.4 Timer/Counter 2 Mode Control (T2MOD)

| Location                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       | 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---|---|---|---|---|------|------|----------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Read  |   |   |   |   |   | T10E | T2OE | DCEN                                                                                         |
| C9H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Write | - | - | - | - | - |      |      |                                                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset | Х | Х | Х | Х | Х | 0    | 0    | 0                                                                                            |
| Symbol       Function         -       Not implemented         X       Not defined         T1OE       Timer 1 Output Enable bit         1: Enable Timer 1 output. Bit C/T#_T1 must be cleared. A 50% duty cycle output. T1OE bit does not affect T1 overflow interrupt         0: Disable Timer 1 output         T2OE         Timer 2 Output Enable bit         1: Enable Timer 2 output. Bit C/T2# must be cleared. A 50% duty cycle wortput. If T2OE = 1, TF2 overflow flag will not be set on Timer 2 roll-over, overflow interrupt will not be generated. If T2OE = 0, TF2 overflow interrupt affected.         0: Disable Timer 2 output         DOEN |       |   |   |   |   |   |      |      |                                                                                              |
| affected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |   |   |   |   |   |      |      | TF2 bit. This<br>reloaded into<br>ner 2 count<br>values stored<br>s FFFFH to<br>s bit can be |



# 10.4 Watchdog Timer (WDT)

A watchdog timer (WDT) is a hardware timer that offers protection against software and/or hardware deadlock during normal operation. When the WDT is enabled, it will generate a chip reset or interrupt if the user program does not reload the WDTDAT register within a specified time interval. The frequency of the XCLK clock source for the WDT is 32.768 KHz. The WDT has a 9-bit prescaler, which makes the watchdog timer resolution equal to approximately 16.0ms. Hence, the 8-bit watchdog counter provides a watchdog time interval from 16ms to 4 seconds. Both the watchdog counter and the prescaler are reset when the unit is disabled.





After POR, BOR, External reset, WDT reset, or aLPC Soft reset the WDT is disabled. The WDT commences counting down from the loaded WDT data value as soon as enable bit WDTEN in WDTCSR register is set.

Once activated, the WDT must be reloaded periodically in software before the programmed WDT interval expires. Otherwise, the WDT will underflow and a WDT reset or interrupt will be generated.

WDT reset is controlled by the WDTRSTEN bit in RST-CON register, and WDT interrupt is controlled by the WDT-MSK bit in INTSRCAMSK register. Both WDT reset and WDT interrupt will generate an output signal on GPIO48 if it is selected as WDT output pin. When WDT reset is enabled (WDTRSTEN = 1), this output will be asserted for one 32KHz clock cycle. When WDT reset is disabled, and WDT interrupt is enabled (WDTMSK = 1), this output will stay asserted until the interrupt is cleared; WDT will stay in underflow state and will not wrap around. When data register is reloaded or WDT is disabled by clearing WDTEN = 0, the underflow state is exited. On exit from underflow state WDT interrupt is cleared, and WDT output is deasserted. It is possible to prevent both WDT reset and WDT interrupt from happening when WDTRSTEN = WDTMSK = 0.

There are two methods to disable the WDT operation at run time: (1) clear the WDT enable bit directly, or (2) reload the WDT data register with 00H, which will automatically clear WDT enable bit.



### 10.4.1 Watchdog Timer MMCRs

### 10.4.1.1 Watchdog Timer Control / Status Register (WDTCSR)

| Location |       | 7      | 6                                                                                                                                     | 5                                                                                                                                                                                                       | 4                                                                                                                                             | 3                                                                                                                            | 2                                                                               | 1     | 0                                               |
|----------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-------|-------------------------------------------------|
|          | Read  | WDT-   |                                                                                                                                       |                                                                                                                                                                                                         |                                                                                                                                               |                                                                                                                              |                                                                                 | WDTEN | WLE                                             |
| 7F37H    | Write | STOPEN | -                                                                                                                                     | -                                                                                                                                                                                                       | -                                                                                                                                             | -                                                                                                                            | -                                                                               |       |                                                 |
|          | Reset | 0      | Х                                                                                                                                     | Х                                                                                                                                                                                                       | Х                                                                                                                                             | Х                                                                                                                            | Х                                                                               | 0     | 0                                               |
|          | Wine  |        | Not def<br>WDT P<br>1: WDT<br>enabled<br>0: WDT<br>resume<br>WDT E<br>when lo<br>1: Enab<br>0: Disal<br>Watcho<br>register<br>1: Enab | elemented<br>ined<br>ower Down i<br>keeps runni<br>d.<br>is stopped v<br>s running af<br>nable bit. Se<br>bading 00H to<br>ble WDT ope<br>oble WDT ope<br>log Load Ens<br>Automatica<br>ble writes to v | ing when 80<br>when 8051 of<br>ter Power D<br>ot by firmwar<br>o WDTDAT<br>eration<br>eration<br>able bit. Set<br>illy cleared v<br>WDTDAT re | 51 enters into<br>enters into P<br>own exit star<br>e to enable (<br>register.<br>by firmware<br>vhen writing<br>gister (WDT | o Power Down r<br>ower Down r<br>ing with the<br>(start) the Wi<br>to enable wi |       | utomatically<br>DFFH.<br>cally cleared<br>DTDAT |

### 10.4.1.2 Watchdog Data Register (WDTDAT)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | WDTDAT7 | WDTDAT6 | WDTDAT5 | WDTDAT4 | WDTDAT3 | WDTDAT2 | WDTDAT1 | WDTDAT0 |
| 7F38H    | Write |         |         |         |         |         |         |         |         |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

Symbol

# Function

WDTDAT[7:0]

# WDT data

When written to and WLE = 1, the WDT timer is initialized (counter is loaded with the respective data byte, and prescaler is reset). When read, it will return the current value. The watchdog timer (WDT) must be reloaded within the periods that are shorter than the programmed watchdog interval; otherwise the WDT will underflow.

Note: Recommended WDT start software sequence: set WLE = 1 first, next load WDTDAT, and finally set WDTEN = 1



# 10.5 Hibernation Timer

SST79LF008 has a hibernation timer which allows for hibernation time of up to 127.5 minutes in 30-second intervals. The XCLK clock source for the hibernation timer is derived from a 32.768 KHz crystal. In order to generate a 30-second time interval, there is a 20-bit prescaler which counts up from 0 to F0000H and then wraps around to zero. The hibernation time counter is a down-counter which does not wrap around after reaching zero value. Interrupt and wakeup events are generated when hibernation timer reaches zero value. When a non-zero value is written into HIBER register hibernation timer is re-started and the respective interrupt is cleared. The relationship between the prescaler and the down counter can be seen in Figure 10-2 below.



#### FIGURE 10-2: Hibernation Timer

### 10.5.1 Hibernation Timer Register (HIBER)

| Location |       | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|----------|-------|------|------|------|------|------|------|------|------|
|          | Read  | HIB7 | HIB6 | HIB5 | HIB4 | HIB3 | HIB2 | HIB1 | HIB0 |
| 7FF3H    | Write |      |      |      |      |      |      |      |      |
|          | Reset | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

Symbol HIB[7:0]

#### Function

Hibernation time in 30 second intervals

00H: Hibernation time = 0 seconds

01H: Hibernation time = 30 seconds

02H: Hibernation time = 1 minute

03H: Hibernation time = 1.5 minutes...

Continues to increment in 30 second intervals until

FFH: Hibernation time = 127.5 minutes



# 10.6 Pulse Width Modulators (PWM)

The SST79LF008 device has three independent PWM channels. Each of them has 16-bit prescaler, 8-bit cycle time register, and 8-bit duty cycle control register. The PWM clock can be derived from 8051 core clock CCLK which causes the frequency to be  $F_{PWM} = F_{CCLK}$  or from 32.768 KHz crystal oscillator clock XCLK which causes the frequency to be  $F_{PWM} = 32.768$ KHz (selected by PWM control register).

The prescaler output frequency is determined as  $F_{PWMP} = F_{PWM}$  / ((PWMPHn:PWMPLn)+1). The PWM output cycle time can be found as  $T_{PWMC} = (PWMCn+1) / F_{PWMP}$ , and the

PWM output Duty Cycle = (PWMDn+1) / (PWMCn+1) x100%. The PWM Duty Cycle specifies the fraction of the PWM cycle for which the output signal is high. In the case where PWMDn = PWMCn the PWM output is always high. If PWMDn > PWMCn, then the PWM output is always low.

The device also includes an additional PWM timer with five "555-like" 300ms interval "blinking" outputs for LED control. The clock source for this PWM timer is 32.768 KHz XCLK signal.

### 10.6.1 PWM MMCRs

### 10.6.1.1 PWM Channel 0 Prescaler Register Low Byte (PWMPL0)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | PWMPL0 |
| 7F25H    | Write | _7     | _6     | _5     | _4     | _3     | _2     | _1     | _0     |
|          | Reset | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |

### 10.6.1.2 PWM Channel 1 Prescaler Register Low Byte (PWMPL1)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | PWMPL1 |
| 7F26H    | Write | _7     | _6     | _5     | _4     | _3     | _2     | _1     | _0     |
|          | Reset | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |

### 10.6.1.3 PWM Channel 2 Prescaler Register Low Byte (PWMPL2)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | PWMPL2 |
| 7F29H    | Write | _7     | _6     | _5     | _4     | _3     | _2     | _1     | _0     |
|          | Reset | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |

**Symbol** PWMPLn[7:0]

#### Function

PWM channel 0-2 prescaler low byte. When PWMPLn (n=0-2) register is modified, the PWMn output can be unpredictable for no more than one PWMn cycle. The output frequency of the prescaler is  $F_{PWM}/((PWMPHn:PWMPLn)+1)$ .



### 10.6.1.4 PWM Channel 0 Prescaler Register High Byte (PWMPH0)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | PWMPH0 |
| 7F97H    | Write | _7     | _6     | _5     | _4     | _3     | _2     | _1     | _0     |
|          | Reset | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |

#### 10.6.1.5 PWM Channel 1 Prescaler Register High Byte (PWMPH1)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | PWMPH1 |
| 7F98H    | Write | _7     | _6     | _5     | _4     | _3     | _2     | _1     | _0     |
|          | Reset | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |

#### 10.6.1.6 PWM Channel 2 Prescaler Register High Byte (PWMPHn)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | PWMPH2 |
| 7F99H    | Write | _7     | _6     | _5     | _4     | _3     | _2     | _1     | _0     |
|          | Reset | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |

Symbol PWMPHn[7:0]

### Function

PWM channel 0-2 prescaler high byte. When PWMPHn (n=0-2) register is modified, the PWMn output can be unpredictable for no more than one PWMn cycle. The output frequency of the prescaler is  $F_{PWM}/((PWMPHn:PWMPLn)+1)$ .

### 10.6.1.7 PWM Channel 0 Cycle Time Register (PWMC0)

| Location |       | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|          | Read  | PWMC0 |
| 7F9AH    | Write | _7    | _6    | _5    | _4    | _3    | _2    | _1    | _0    |
|          | Reset | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

#### 10.6.1.8 PWM Channel 1 Cycle Time Register (PWMC1)

| Location |       | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|          | Read  | PWMC1 |
| 7F9BH    | Write | _7    | _6    | _5    | _4    | _3    | _2    | _1    | _0    |
|          | Reset | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

#### 10.6.1.9 PWM Channel 2 Cycle Time Register (PWMC2)

| Location |       | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|          | Read  | PWMC2 |
| 7F9CH    | Write | _7    | _6    | _5    | _4    | _3    | _2    | _1    | _0    |
|          | Reset | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

Symbol PWMCn[7:0]

#### Function

PWM channel 0-2 cycle time value. The 8-bit down-counter divides the prescaler output frequency by (PWMCn+1). When PWMCn (n=0-2) register is modified, the PWMn output can be unpredictable for no more than one PWMn cycle.



### 10.6.1.10 PWM Channel 0 Duty Cycle Time Register (PWMD0)

| Location |       | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|          | Read  | PWMD0 |
| 7F9DH    | Write | _7    | _6    | _5    | _4    | _3    | _2    | _1    | _0    |
|          | Reset | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

#### 10.6.1.11 PWM Channel 1 Duty Cycle Time Register (PWMD1)

| Location |       | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|          | Read  | PWMD1 |
| 7F9EH    | Write | _7    | _6    | _5    | _4    | _3    | _2    | _1    | _0    |
|          | Reset | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

### 10.6.1.12 PWM Channel 2 Duty Cycle Time Register (PWMD2)

| Location |       | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|          | Read  | PWMD2 |
| 7F9FH    | Write | _7    | _6    | _5    | _4    | _3    | _2    | _1    | _0    |
|          | Reset | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

Symbol PWMDn[7:0]

### Function

PWM channel 0-2 duty cycle value. This value defines the number of prescaler clocks for which PWM output is high. When PWMDn (n=0-2) register is modified, the new duty cycle will be in effect starting with the next PWMn cycle. Duty Cycle = ((PWMDn+1) / (PWMCn+1)) x 100% If PWMDn=PWMCn, then PWM output is always high (Duty Cycle = 100%) If PWMDn > PWMCn PWM output is always low (Duty Cycle = 0%)

| Location |       | 7      | 6      | 5      | 4      | 3 | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|---|--------|--------|--------|
|          | Read  | PWM4_L | PWM4_L | PWM3_L | PWM3_L | - | PWM2_S | PWM1_S | PWM0_S |
| 7F96H    | Write | ED1    | ED0    | ED1    | ED0    |   | EL     | EL     | EL     |
|          | Reset | 0      | 0      | 0      | 0      | Х | 0      | 0      | 0      |

#### 10.6.1.13 PWM Control Register (PWMCR)

| Symbol     |          | Functio  | n             |                |               |               |                         |               |
|------------|----------|----------|---------------|----------------|---------------|---------------|-------------------------|---------------|
| -          |          | Not imp  | lemented      |                |               |               |                         |               |
| Х          |          | Not defi | ned           |                |               |               |                         |               |
| PWM[2:0]_9 | SEL      | PWM c    | nannel 2-0 c  | lock source \$ | Selection bit |               |                         |               |
|            |          | 1: Selec | t XCLK - FP   | wм = 32.768I   | KHz, PWM k    | keeps runnin  | g when 805 <sup>.</sup> | 1 is in Power |
|            |          | Down m   | node.         |                |               |               |                         |               |
|            |          | 0: Selec | t 8051 core   | clock CCLK     | - FPWM = FC   | CLK. PWM is : | stopped whe             | n 8051 is in  |
|            |          | Power D  | Down mode.    |                |               |               |                         |               |
| PWM[4:3]_L | _ED[1:0] | LED 4-3  | 3 output cont | trol bits      |               |               |                         |               |
|            |          |          |               |                |               |               |                         |               |



# 10.6.1.14 PWM 555 Like LED Control Register (PWM555CR1)

| Location |        | 7 | 6             | 5             | 4            | 3             | 2             | 1             | 0             |
|----------|--------|---|---------------|---------------|--------------|---------------|---------------|---------------|---------------|
| 7F21H    | Read   | - | PWM2_L<br>ED1 | PWM2_L<br>ED0 | PWR-<br>GOOD | PWM1_L<br>ED1 | PWM1_L<br>ED0 | PWM0_L<br>ED1 | PWM0_L<br>ED0 |
|          | Write  |   |               |               | -            |               |               |               |               |
|          | Reset  | Х | 0             | 0             | PWR-<br>GOOD | 0             | 0             | 0             | 0             |
|          | Symbol |   | Functio       | on            |              |               |               |               |               |

| Not impleme   |
|---------------|
| NILL ALCOLUMN |

| Not implemented                                                 |
|-----------------------------------------------------------------|
| Not defined                                                     |
| LED 2-0 output control bits                                     |
| Status of POWERGOOD Pin (reset value = pass through pin state). |
|                                                                 |

# TABLE 10-6: LED 4/2/0 Behavior

| Control Bits: | Output Behavior                           |
|---------------|-------------------------------------------|
| PWM4_LED[1:0] | LED4                                      |
| PWM2_LED[1:0] | LED2                                      |
| PWM0_LED[1:0] | LED0                                      |
| 00            | Output high (LED is Off)                  |
| 01            | Output low = 0.125s, Output period = 1.0s |
| 10            | Output low =0.125s, Output period = 0.5s  |
| 11            | Output low (LED is On)                    |
|               | T10-6.1320                                |

#### TABLE 10-7: LED 3/1 Behavior

| Control Bits: | Output Behavior                           |
|---------------|-------------------------------------------|
| PWM3_LED[1:0] | LED3                                      |
| PWM1_LED[1:0] | LED1                                      |
| 00            | Output high (LED is Off)                  |
| 01            | Output low = 0.125s, Output period = 3.0s |
| 10            | Output low =0.125, Output period = 1.5s   |
| 11            | Output low (LED is On)                    |

T10-7.1320

Note: 555, like PWM, uses 32.768KHz and runs in Power Down mode.



# 11.0 SERIAL I/O PORT (UART)

# 11.1 Full-Duplex, Enhanced UART

The SST79LF008 serial I/O port is a full-duplex, enhanced UART port that uses the transmit and receiver registers to simultaneously transmit and receive data in the hardware while the software is performing other tasks. The transmit and receive registers are both located in the Serial Data Buffer (SBUF) special function register. Writing to the SBUF register loads the transmit register, while reading from the SBUF register obtains the contents of the receive register. The enhanced UART features framing error detection and automatic address recognition.

The UART has four modes of operation which are selected by the Serial Port Mode selection bits (SM0 and SM1) of the Serial Port Control (SCON) special function register. In all four modes, transmission is initiated by any instruction that uses the SBUF register as a destination register. Reception is initiated in mode 0 when the Receive Interrupt (RI) flag bit of the Serial Port Control (SCON) SFR is cleared and the Reception Enable/ Disable (REN) bit of the SCON register is set. Reception is initiated in the other modes by the incoming start bit, if the REN bit of the SCON register is set.

# **11.2 Framing Error Detection**

Framing Error Detection allows checking for valid stop bit during receive operation in serial modes 1, 2, and 3. An incorrect stop bit could be caused by noise in the serial line, simultaneous transmissions by two CPUs, or mismatched baud rates between transmitter and receiver. Serial mode 0 does not permit Framing Error Detection because it employs a synchronous serial protocol that does not use stop bit.

Framing Error Detection is selected in the PCON register by setting SMOD0 = 1, see Figure 11-1. If a stop bit is missing, the Framing Error bit (FE) at SCON[7] will be set. The software examines the FE bit after each received bit to check for data errors. After the FE bit is set, it can only be cleared by software. Valid stop bits do not clear the FE bit. When Framing Error Detection is enabled, RI rises on the stop bit, instead of the last data bit. See Figures 11-2 and 11-3.













FIGURE 11-3: UART Timings in Modes 2 and 3

# **11.3 Automatic Address Recognition**

Automatic Address Recognition helps reduce the time and power required to interface and communicate with multiple serial devices. All connected devices share the same serial link, and each device has its own address. In this configuration, a device is only interrupted when it receives its own address, group address, or broadcast address. This process eliminates the software overhead to compare addresses.

Automatic Address Recognition saves power by working in conjunction with the idle mode, thereby reducing the system's overall power consumption. Since there may be multiple slaves connected serially to one master, only one slave would have to be interrupted from the idle mode to respond to the master's transmission. During this transmission, Automatic Address Recognition (AAR) allows all the other slaves to remain in idle mode. Limiting the number of interruptions reduces the total current drawn from the system.

There are two ways to communicate with slaves—by group or all at once. To communicate with a group of slaves, the master sends out an address called the "given address". To communicate with all the slaves, the master sends out an address called the "broadcast" address.

Enable AAR in mode 2 or 3 (9-bit modes) by setting the SM2 bit in SCON. Each slave has its own SM2 bit set waiting for an address byte (9th bit = 1). The Receive Interrupt (RI) flag will only be set when the received byte matches either the given address or the broadcast address. Next, the slave then clears its SM2 bit to enable reception of the data bytes (9th bit = 0) from the master. When the 9th bit = 1, the master is sending an address. When the 9th bit = 0, the master is sending the actual data.

If mode 1 is used, the stop bit takes the place of the 9th bit. Bit RI is set only when the received command frame address matches the device's address, and is terminated by a valid stop bit. Note that AAR is not available in mode 0. Setting SM2 bit in the SCON register in mode 0 will have no effect.

## 11.3.1 Using the Given Address to Select Slaves

Given addresses are used to address an individual slave or a group of slaves. A slave may have one or more given addresses because of "don't care" bits. The given address is computed by a logical AND operation of the SADDR value and the SADEN value. Any bit masked off by a 0 from SADEN becomes a "don't care" represented by 'X' in the example below.

| Slave 1 |   |   |      |      |  |
|---------|---|---|------|------|--|
| SADDR   | = |   | 1111 | 0001 |  |
| SADEN   | = |   | 1111 | 1010 |  |
| GIVEN   | = | _ | 1111 | 0X0X |  |
| Slave 2 |   |   |      |      |  |
| SADDR   | = |   | 1111 | 0011 |  |
| SADEN   | = |   | 1111 | 1001 |  |
| GIVEN   | = | _ | 1111 | 0XX1 |  |

Because of the "don't care" bits, multiple slaves may respond to a given address as shown in Table 11-1. Continuing the above example, slave 1 has an individual address of 11110001 loaded into SADDR. The SADEN byte has been used to mask off bits for a given address to allow more combinations of selecting slave 1 and 2. In this case for the given addresses, the last bit (LSB) of slave 1 is a "don't care" and the last bit slave 2 is a 1. Similarly for slave 2, the second to last bit is a "don't care" and that of slave 1 is a 0. Thus to communicate with slave 1 and 2, the master would need to send an address with the last two bits equal to 01 (e.g. 1111 0001). To communicate with slave 1 only, the last two bits must be 00 (e.g. 1111 0000).



| Target Slave  | Given Address | All Possible Addresses |
|---------------|---------------|------------------------|
| Slave 1 only  | 1111 0X0X     | 1111 0000              |
|               |               | 1111 0100              |
| Slave 2 only  | 1111 0XX1     | 1111 0111              |
|               |               | 1111 0011              |
| Slave 1 and 2 | 1111 0XXX     | 1111 0001              |
|               |               | 1111 0101              |

T11-1.0 1320

| If the user added a third slave, the slave 3 example in Table |         |   |      |      |  |
|---------------------------------------------------------------|---------|---|------|------|--|
| 11-2 provides its Given Address calculation, and Table 11-    | Slave 3 |   |      |      |  |
| 2 indicates all possible addresses for Slave 3 and the com-   | SADDR   | = | 1111 | 1001 |  |
| bination of Slaves 2 and 3.                                   | SADEN   | = | 1111 | 0101 |  |
|                                                               | GIVEN   | = | 1111 | X0X1 |  |

### TABLE 11-2: Possible Addresses for Slave 3 and Slave 2/3 Combination

| Target Slave       | Given Address | All Possible Addresses |
|--------------------|---------------|------------------------|
| Slave 3 only       | 1111 X0X1     | 1111 1011              |
|                    |               | 1111 1001              |
| Slave 2 and 3 only | 1111 XXX1     | 1111 0011              |

T11-2.0 1320

### **11.3.2 Using the Broadcast Address to Select Slaves**

Using the Broadcast Address, the master can communicate with all the slaves at once. The broadcast address is formed by performing a logical OR of SADDR and SADEN with zeros in the result treated as "don't cares".

| Slave 1     |             |
|-------------|-------------|
| 1111 0001   | = SADDR     |
| + 1111 1010 | = SADEN     |
| 1111 1X11   | = Broadcast |

"Don't cares" allow for a wider range in defining the Broadcast Address, but in most cases, the Broadcast Address will be FFH.

On reset, SADDR and SADEN are '0'. This produces a Given Address of all "don't cares" as well as a Broadcast Address of all "don't cares". This effectively disables Automatic Addressing mode.



# 11.4 UART SFRs

| 11.4.1 Power Control | Register (PCON) |
|----------------------|-----------------|
|----------------------|-----------------|

| Location |                | 7             | 6                                                                            | 5                | 4                              | 3               | 2              | 1             | 0                |  |  |
|----------|----------------|---------------|------------------------------------------------------------------------------|------------------|--------------------------------|-----------------|----------------|---------------|------------------|--|--|
|          | Read           | SMOD1         | SMOD0                                                                        | BOF <sup>1</sup> | POF <sup>1</sup>               | GF1             | GF0            | PD            | IDL              |  |  |
| 87H      | Write          |               |                                                                              |                  |                                |                 |                |               |                  |  |  |
|          | Reset          | 0             | 0                                                                            | 0                | 1                              | 0               | 0              | 0             | 0                |  |  |
| 1. These | bits are reset | by Power-On r | eset only (all c                                                             | ther reset eve   | ents have no a                 | ffect)          |                |               |                  |  |  |
|          | Symbol         |               | Functi                                                                       | on               |                                |                 |                |               |                  |  |  |
|          | SMOD1          |               |                                                                              |                  |                                |                 | •              |               | baud rate, and   |  |  |
|          |                |               | the ser                                                                      | ial port is us   | ed in modes                    | ; 1, 2, and 3,  | then baud ra   | ate is double | ed.              |  |  |
|          | SMOD0          |               |                                                                              |                  | ection contro                  | ol bit.         |                |               |                  |  |  |
|          |                |               |                                                                              | N[7] = FE b      |                                |                 |                |               |                  |  |  |
|          | _              |               |                                                                              | N[7] = SM0       |                                |                 |                |               |                  |  |  |
|          | BOF            |               |                                                                              |                  |                                |                 | prown-out is o |               |                  |  |  |
|          |                |               |                                                                              |                  | also cleared                   | d after Powe    | r-On reset. It | is not affect | ed by any        |  |  |
|          |                |               | 0                                                                            | eset event.      |                                |                 |                | ·             |                  |  |  |
|          | POF            |               |                                                                              |                  | tus flag. Set<br>er reset evel |                 | cleared by so  | ittware. This | bit is not       |  |  |
|          | GF1            |               | Genera                                                                       | al-purpose fl    | ag bit                         |                 |                |               |                  |  |  |
|          | GF0            |               | Genera                                                                       | al-purpose fl    | ag bit                         |                 |                |               |                  |  |  |
|          | PD             |               | Power                                                                        | Down mode        | bit. Setting                   | this bit activa | tes Power D    | own mode (    | refer to Figure  |  |  |
|          |                |               | 5-3). It                                                                     | is cleared by    | y hardware a                   | after exiting F | Power Down     | mode by on    | e of the reset   |  |  |
|          |                |               | (see Table 5-1) or enabled wakeup event (see Figure 8-1 through Figure 8-5). |                  |                                |                 |                |               |                  |  |  |
|          |                |               |                                                                              |                  | Down mode                      |                 |                |               |                  |  |  |
|          |                |               |                                                                              |                  | de is not act                  |                 |                |               |                  |  |  |
|          | IDL            |               |                                                                              |                  |                                |                 |                |               | It is cleared by |  |  |
|          |                |               |                                                                              |                  |                                |                 | e of the rese  |               | 5-1) or          |  |  |
|          |                |               |                                                                              | •                |                                | gure 8-1 thro   | ugh Figure 8   | -5.           |                  |  |  |
|          |                |               |                                                                              | ates idle mo     |                                |                 |                |               |                  |  |  |
|          |                |               | 0: Idle i                                                                    | mode is not      | activated                      |                 |                |               |                  |  |  |

### 11.4.2 Slave Address Register (SADDR)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | SADDR7 | SADDR6 | SADDR5 | SADDR4 | SADDR3 | SADDR2 | SADDR1 | SADDR0 |
| A9H      | Write |        |        |        |        |        |        |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol SADDR[7:0] Function

UART slave address

# 11.4.3 Slave Address Mask Register (SADEN)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | SADEN7 | SADEN6 | SADEN5 | SADEN4 | SADEN3 | SADEN2 | SADEN1 | SADEN0 |
| B9H      | Write |        |        |        |        |        |        |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol SDAEN[7:0] Function

UART slave address mask



### 11.4.4 Serial Port UART Data Register (SBUF)

| Location |       | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|          | Read  | SBUF7 | SBUF6 | SBUF5 | SBUF4 | SBUF3 | SBUF2 | SBUF1 | SBUF0 |
| 99H      | Write |       |       |       |       |       |       |       |       |
|          | Reset | Х     | Х     | Х     | Х     | Х     | Х     | Х     | Х     |

Symbol X SBUF[7:0] Function Not defined

UART data buffer

### 11.4.5 Serial Port Control Register (SCON)

| Location |       | 7      | 6   | 5   | 4   | 3   | 2   | 1  | 0  |
|----------|-------|--------|-----|-----|-----|-----|-----|----|----|
|          | Read  | SM0/FE | SM1 | SM2 | REN | TB8 | RB8 | TI | RI |
| 98H      | Write |        |     |     |     |     |     |    |    |
|          | Reset | 0      | 0   | 0   | 0   | 0   | 0   | 0  | 0  |

| Symbol | Function                                                                                                                                                                                                                                                                                                                                                                  |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FE     | Framing Error bit (set SMOD0 = 1 to access FE bit)<br>1: Framing Error. Set by receiver when invalid stop bit is detected, cleared by software                                                                                                                                                                                                                            |
|        | 0: No framing error detected                                                                                                                                                                                                                                                                                                                                              |
| SM0    | Serial Port Mode Bit 0 (clear SMOD0 = 0 to access SM0 bit)                                                                                                                                                                                                                                                                                                                |
| SM1    | Serial Port Mode Bit 1                                                                                                                                                                                                                                                                                                                                                    |
| SM2    | Enables the Automatic Address Recognition feature in Modes 2 or 3. In these modes, if $SM2 = 1$ then RI will not be set unless the received 9th data bit (RB8) is 1, indicating an address, and the received byte is a Given or Broadcast address. In Mode 1, if $SM2 = 1$ then RI will not be set unless a valid stop bit has been received. In Mode 0, SM2 should be 0. |
| REN    | Enables serial reception<br>1: Enable reception.<br>0: Disable reception.                                                                                                                                                                                                                                                                                                 |
| TB8    | The 9th data bit that will be transmitted in Modes 2 and 3. This bit is set or cleared by software as desired.                                                                                                                                                                                                                                                            |
| RB8    | In Modes 2 and 3, RB8 is the 9th data bit that has been received. In Mode 1, if $SM2 = 0$ , RB8 is the stop bit that has been received. In Mode 0, RB8 is not used.                                                                                                                                                                                                       |
| ТІ     | Transmit interrupt flag. Set by hardware at the end of the 8th bit time in Mode 0, or at the beginning of the stop bit in the other modes, in any serial transmission. Must be cleared by software.                                                                                                                                                                       |
| RI     | Receive interrupt flag. Set by hardware at the end of the 8th bit time in Mode 0, or halfway through the stop bit time in the other modes, in any serial reception (except see SM2). Must be cleared by software.                                                                                                                                                         |

| TABLE 11 | 1-3: Serial | Port Mode | Description |
|----------|-------------|-----------|-------------|
|----------|-------------|-----------|-------------|

| SM0 | SM1 | Mode | Description    | Baud Rate <sup>1</sup>                        |
|-----|-----|------|----------------|-----------------------------------------------|
| 0   | 0   | 0    | Shift Register | FCCLK / 12                                    |
| 0   | 1   | 1    | 8-bit UART     | Variable <sup>2,3</sup>                       |
| 1   | 0   | 2    | 9-bit UART     | FCCLK /16 (SMOD1 =1) or FCCLK /32 (SMOD1 = 0) |
| 1   | 1   | 3    | 9-bit UART     | Variable <sup>2,3</sup>                       |

1. FCCLK = 8051 core clock frequency

2. Variable baud rate if T1 is used as rate generator =  $(2^{SMOD1})^*(T1 \text{ overflow rate})/32$ 

3. Variable baud rate if T2 is used as rate generator = (T2 overflow rate)/16



# 12.0 SERIAL PERIPHERAL INTERFACE (SPI)

# 12.1 SPI Features

- Master or slave operation
- 16 MHz bit frequency (max) master mode
- 8 MHz bit frequency (max) slave mode
- LSB first or MSB first data transfer
- Four programmable bit rates
- End of transmission interrupt (SPIF)
- Write collision flag protection (WCOL)
- Wake up from Idle (master and slave modes)
- Wake up from Power Down modes (slave mode only)

# 12.2 SPI Description

The serial peripheral interface (SPI) allows full-duplex highspeed synchronous data transfer between the SST79LF008 and the peripheral devices.

Figure 12-1 shows the correspondence between master and slave SPI devices. The SCK (GPIO5) pin is the clock output for master mode and input for slave mode.

The SST79LF008 does not output SS#. If the SST79LF008 is the master and there is only one slave device, the slave's SS# input can be tied low. If there is more than one slave, N GPIOs can be used to select N slaves. Another option is external generation of the SS# inputs of multiple slave devices.

When SST79LF008 master mode is selected, the SPI clock generator will start following a write to the SST79LF008 device SPI data register. The written data is

then shifted out of the MOSI (GPIO3) pin into the MOSI pin of the slave device. Following a complete transmission of one byte of data, the SPI clock generator is stopped and the SPIF flag is set. An SPI interrupt request will be generated if the SPI Interrupt Enable bit (SPIE) is set.

When SST79LF008 slave mode is selected, an external master generates SCK clock and drives the Slave Select input pin SS# (GPIO6) low to select the SST79LF008 SPI module as a slave. If the Slave Select input pin has not been driven low, then the SST79LF008 SPI unit is not active and the MOSI port can also be used as an input port pin.

Clock Phase control bit (CPHA) and Clock Polarity (CPOL) control the phase and polarity of the SPI clock. Figures 12-2 and 12-3 show the transfer formats with four possible combinations of these two bits.

To wake up the SST79LF008 from IDLE, whether in master or slave mode, the following conditions must be met: The SPIF bit is set to '1' upon completion of the data transfer, the SPIE is '1', and EA (Enable Global Interrupt bit in interrupt enable register) is '1'. These conditions generate an interrupt that wakes the device from IDLE mode.

In slave mode only, the SST79LF008 wakes up from Power Down when CPHA = 0 or CPHA = 1. When CPHA = 0, a transition from high to low on SS# pin wakes up the device from Power Down mode. When CPHA = 1, the clock edges of SCK wakes up the device from Power Down mode.



FIGURE 12-1: SPI Master-Slave Interconnection



# **12.3 SPI Transfer Formats**











# 12.4 SPI SFRs

# 12.4.1 SPI Control Register (SPCR)

| Location                                |                              | 7    | 6       | 5            | 4              | 3             | 2        | 1              | 0                        |  |
|-----------------------------------------|------------------------------|------|---------|--------------|----------------|---------------|----------|----------------|--------------------------|--|
|                                         | Read                         | SPIE |         | DORD         | MSTR           | CPOL          | CPHA     | SPR1           | SPR0                     |  |
| D5H                                     | Write                        |      | -       |              |                |               |          |                |                          |  |
| D5H<br>-<br>X<br>SPI<br>DO<br>MS<br>CPC | Reset                        | 0    | Х       | 0            | 0              | 0             | 1        | 0              | 0                        |  |
|                                         | Symbol                       |      | Functi  |              |                |               |          |                |                          |  |
|                                         | -                            |      |         | olemented    |                |               |          |                |                          |  |
|                                         |                              |      | Not de  | fined        |                |               |          |                |                          |  |
|                                         | SPIE                         |      |         |              | ssion Interru  | ot Enable bit |          |                |                          |  |
| 1: Enable SPI interrupt                 |                              |      |         |              |                |               |          |                |                          |  |
|                                         | 0: Disable SPI interrupt     |      |         |              |                |               |          |                |                          |  |
|                                         | DORD Data Transmission Order |      |         |              |                |               |          |                |                          |  |
|                                         |                              |      | _       |              | transmissior   |               |          |                |                          |  |
|                                         |                              |      |         |              | transmissio    | n             |          |                |                          |  |
|                                         | MSTR                         |      |         | Slave selec  |                |               |          |                |                          |  |
|                                         |                              |      |         | ct Master m  |                |               |          |                |                          |  |
|                                         |                              |      |         | ct Slave mo  | de             |               |          |                |                          |  |
|                                         | CPOL                         |      | Clock F |              |                |               |          |                |                          |  |
|                                         |                              |      |         |              | n idle (Active |               |          |                |                          |  |
|                                         |                              |      |         |              | n idle (Active | Hign)         |          |                |                          |  |
|                                         | CPHA                         |      |         | Phase contro |                |               |          |                |                          |  |
|                                         |                              |      |         |              | on the trailir |               |          |                |                          |  |
|                                         |                              |      |         |              | on the leadi   | ng eage or i  | IE CIOCK |                |                          |  |
|                                         | SPR1, SPR                    | iU   |         | ock Rate Sel |                | D2 hit in Cl  |          | tor control th | o SCK rate of            |  |
|                                         |                              |      |         |              |                |               |          | ect on the sla | e SCK rate of            |  |
|                                         |                              |      |         |              |                |               |          |                | $_{\rm K}$ , as shown in |  |
|                                         |                              |      |         | 12-1 and 12  |                |               |          | CCLI           |                          |  |
|                                         |                              |      | 100100  |              |                |               |          |                |                          |  |

### TABLE 12-1: SCK Rate as a Function of SPI Clock Rate Select Bits (Master Only)

| SPR2 | SPR1 | SPR0 | SCK Frequency = FccLk divided by |
|------|------|------|----------------------------------|
| 0    | 0    | 0    | 4                                |
| 0    | 0    | 1    | 16                               |
| 0    | 1    | 0    | 64                               |
| 0    | 1    | 1    | 128                              |
| 1    | 0    | 0    | 2                                |
| 1    | 0    | 1    | 8                                |
| 1    | 1    | 0    | 32                               |
| 1    | 1    | 1    | 64                               |

T12-1.1320



| SPR1 | SPR0 | SCK Frequency = FCCLK divided by |  |  |  |  |  |
|------|------|----------------------------------|--|--|--|--|--|
| 0    | 0    | 4                                |  |  |  |  |  |
| 0    | 1    | 16                               |  |  |  |  |  |
| 1    | 0    | 64                               |  |  |  |  |  |
| 1    | 1    | 128                              |  |  |  |  |  |

### TABLE 12-2: SCK Rate as a Function of SPI Clock Rate Select Bits (Slave Only)

T12-2.

## 12.4.2 SPI Status Register (SPSR)

| Location |       | 7    | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|-------|------|------|---|---|---|---|---|---|
|          | Read  | SPIF | WCOL | - | - | - | - | - | - |
| AAH      | Write |      |      |   |   |   |   |   |   |
|          | Reset | 0    | 0    | Х | Х | Х | Х | Х | Х |

| Symbol | Function                                                                                                                    |
|--------|-----------------------------------------------------------------------------------------------------------------------------|
| -      | Not implemented                                                                                                             |
| Х      | Not defined                                                                                                                 |
| SPIF   | SPI Interrupt Flag. Set upon completion of data transfer. If SPIE = 1, an interrupt is then generated. Cleared by software. |
|        | This bit is also automatically cleared by any access to SPDR after reading SPSR<br>with SPIF=1.                             |
| WCOL   | Write Collision Flag. Set if SPI data register is written during data transfer. Cleared by software.                        |
|        | This bit is also automatically cleared by any access to SPDR after reading SPSR with WCOL=1.                                |
|        |                                                                                                                             |

# 12.4.3 SPI Data Register (SPDR)

| Location |       | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|          | Read  | SPDR7 | SPDR6 | SPDR5 | SPDR4 | SPDR3 | SPDR2 | SPDR1 | SPDR0 |
| 86H      | Write |       |       |       |       |       |       |       |       |
|          | Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

SPD[7:0]

### Function

SPI data. When read, returns received data. When written to, the data is to be transmitted. Writing to this register during transfer will be ignored, and will set WCOL bit.



# 13.0 SMBUS INTERFACE

# **13.1 SMBus Features**

- Compatible with SMBus 2.0 specification
- Two SMBus controllers and three SMBus channels
- Selection of SMBus channels through the internal multiplexer
- Support for SMbus master and slave operation
- Software-defined slave address and General Call
   address support
- Support for both polling and interrupt driven operation
- Wake up from Idle and Power Down—slave mode
- Wake up from Idle—master mode

# 13.2 SMBus Channels

The SST79LF008 includes two SMBus controllers, which support three separate two-wire SMBus channels. Each channel consists of Serial Data Line (SDAn, n=0-2) and the Serial Clock Line (SCLn, n=0-2). SMBus controller 0 controls the clock and data lines of the SMBus channel 0 (SCL0,SDA0), SMBus controller 1 controls via internal multiplexer the clock and data lines of SMBus channel 1 (SCL1, SDA1) and SMBus channel 2 (SCL2, SDA2). See Figure 13-1. SSCR, in Register 13.7.1, contains SM1\_EN, SM0\_EN, and CHSEL1



FIGURE 13-1: SMBus Module Block Diagram



# **13.3 SMBus Protocol Overview**

SMBus is a bidirectional two-wire bus, which allows multiple master and slave devices to be connected simultaneously. All SMBus devices must have open drain outputs. The SMBus lines are connected externally to a positive voltage source (up to 5V) via pull-up circuits, and remain high when they are not driven by SMBus devices. The bus master device initiates the SMBus protocol, controls the

bus clock, and terminates the transaction. The slave device responds and transmits the requested data back to the bus master device. Both master and slave devices on the bus can either operate as a transmitter or as a receiver.

Figures 13-2 and 13-3 illustrate bit and byte transfer layers of SMBus interface.



FIGURE 13-2: SMBus Relationship of SDA<sub>n</sub> to SCL<sub>n</sub> for Bit Transfer



FIGURE 13-3: SMBus Byte Transfer

As shown on Figure 13-3, each SMBus transfer is initiated by the master with SMBus start condition (S), and terminated with the stop condition (P). The START condition is created by a high to low transition of the data line SDAn while the clock line SCLn is high. The STOP condition is created by a low to high transition of the data line SDAn while the clock line SCLn is high. The bus is considered to be "busy" after a START condition. The bus status will remain "busy" until a STOP condition is detected.

Between START and STOP condition, the SMBus protocol permits all information including address, command, and data to be transmitted on a serial data line, SDAn, synchronized with a serial clock SCLn. A single data bit is transferred per each SCLn clock pulse. As shown on Figure 13-2, throughout the SCLn clock's high period, the data on SDAn line is kept stable by the transmitter, and can be sampled by the receiver. New data is sent by the transmitter only during the low state of the SCLn clock. At each clock cycle, the slave can hold SCLn low for an extended period of time when the slave is still handling the previous data or is preparing a new data. There are typically two cases which may cause the slave to hold the bus: a byte received has not been processed, or the next byte to be transmitted is not ready. Under these circumstances, the slave will extend the clock low state.

The SMBus bytes are always transferred with the most significant bit first. An acknowledgement (ACK) cycle is appended at the end of each data byte (i.e., each byte transfer requires nine clock pulses with ACK being the ninth clock). The clock pulse for SMBus ACK clock cycle is always generated by the master device, but the ACK data bit is sent by the receiving device (master or slave). The transmitter must release the data line SDAn during ACK clock allowing the receiver to control the data line. The receiver asserts a low level on the data line during the ACK clock pulse to acknowledge that it has received the last data byte correctly.



If invalid command or data is detected or the receiver is busy, it may send a negative acknowledge (NACK) to indicate that it will not accept any additional data bytes. NACK is recognized when a high level is detected on the data line during the ACK clock pulse. There is an exception when NACK must be generated after a valid byte transfer. If the bus master is the receiver, it must indicate to the slave transmitter an end of data. It does this by responding with NACK to the last byte clocked out of the slave device. Each slave device on the SMBus must have a unique slave address. The master transmits the address of the targeted slave device in the first seven bits after a START condition. The eighth bit, R/W#, specifies the direction of data transfer. See Figure 13-4. The slave device can operate as a transmitter or a receiver depending on the value of R/W# bit (1= slave transmitter, 0=slave receiver). The slave device must always acknowledge its own address.



FIGURE 13-4: SMBus Address Transfer

It is possible for multiple masters to generate a START condition and then continue the transfer simultaneously. An arbitration mechanism is provided by the SMBus protocol for this case. Arbitration takes place on the SDAn line to prevent contention on the bus between masters while the SCLn line is at the high level. If a master attempts to send data bit '1' over the bus, and detects SDAn at a low level driven by another master, it will abort the data transfer because the current level on the bus does not match its own. The master that loses the arbitration can generate clock pulses until the end of the last-transmitted data byte. If a master loses the arbitration during the addressing phase, it is possible that the master which has won the arbitration was attempting to address the master which has lost. In this case, the losing master must immediately switch to the slave receiver mode, and acknowledge its own slave address.

See System Management Bus specification, Version 2.0 for more details on SMBus protocol.

# 13.4 SMBus MMCRs

There are four MMC registers associated with each of the two SMBus controllers. These registers are Multi-master bus control register, Multi-master bus control/status register, Multi-master bus address register, and Multi-master bus transmit/receive data shift register. In addition there are two registers common for both controllers: SMBus switch register and SMBus line status register. All register types are explained in Table 13-1.



# TABLE 13-1: SMBus MMCRs

|                   |                                                         |         |                | Bit Ad         | dress, Sy     | mbol, or        | Alternativ    | ve Port Fi      | unction         |               | Reset<br>Value |
|-------------------|---------------------------------------------------------|---------|----------------|----------------|---------------|-----------------|---------------|-----------------|-----------------|---------------|----------------|
| Symbol            | Description                                             | Address | MSB            |                |               |                 |               |                 |                 | LSB           |                |
| SMCR0             | Multi-Master<br>Bus Control                             | 7F31H   | ACKEN          | CLKSEL         | INTEN         | INT             | TXCLK3        | TXCLK2          | TXCLK1          | TXCLK0        | 00H            |
| SMSR0             | Multi-Master<br>Bus Control /<br>Status                 | 7F32H   | SMSR0_<br>MOD1 | SMSR0_<br>MOD0 | SMSR0_<br>BSY | SMSR0_<br>SEREN | SMSR0_<br>ARB | SMSR0_<br>ADDRS | SMSR0_<br>ADDR0 | SMSR0_<br>ACK | 00H            |
| SAR0              | Multi-Master<br>Bus Address                             | 7F33H   |                | SAR0[7:0]      |               |                 |               |                 |                 | dx0000000     |                |
| SDSR0             | Multi-Master<br>Bus Transmit /<br>Receive Data<br>Shift | 7F34H   |                |                |               | SDSI            | R0[7:0]       |                 |                 |               | 00H            |
| SMCR1             | Multi-Master<br>Bus Control                             | 7F67H   | ACKEN          | CLKSEL         | INTEN         | INT             | TXCLK3        | TXCLK2          | TXCLK1          | TXCLK0        | 00H            |
| SMSR1             | Multi-Master<br>Bus Control /<br>Status Regis-<br>ter   | 7F68H   | SMSR1_<br>MOD1 | SMSR1_<br>MOD0 | SMSR1_<br>BSY | SMSR1_<br>SEREN | SMSR1_<br>ARB | SMSR1_<br>ADDRS | SMSR1_<br>ADDR0 | SMSR1_<br>ACK | 00H            |
| SAR1              | Multi-Master<br>Bus Address                             | 7F69H   |                |                |               | SAF             | 1[7:0]        |                 |                 |               | 000000xb       |
| SDSR1             | Multi-Master<br>Bus Transmit /<br>Receive Data<br>Shift | 7F6AH   |                | SDSR1[7:0]     |               |                 |               |                 |                 |               | 00H            |
| SLSR <sup>1</sup> | SMBus Line<br>Status Regis-<br>ter                      | 7F88H   | -              | -              | SCL2          | SDA2            | SCL1          | SDA1            | SCL0            | SDA0          | -              |
| SSCR              | SMBus<br>Switch Con-<br>trol Register                   | 7F89H   | SM1_EN         | SM0_EN         | -             | -               | -             | P1_SEL          | UART_<br>SM     | CHSEL1        | 00xxx001b      |

1. No reset value is specified for SLSR since this is just pass through register.

T13-1.1245

# 13.5 SMBus Multi-master Control and Status Registers

The SMBus control and status registers are used to control SMBus operations.

### 13.5.1 Multi-Master Bus Control Register (SMCR0)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | SMCR0_ |
| 7F31H    | Write | ACKEN  | CLKSEL | INTEN  | INT    | TXCLK3 | TXCLK2 | TXCLK1 | TXCLK0 |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |



# 13.5.2 Multi-Master Bus Control Register (SMCR1)

| Location |                                | 7      | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 5                                                                                                                                                                          | 4                                                                                                                                                                       | 3                                                                                                              | 2                                                                                     | 1                                                                     | 0                                              |  |  |
|----------|--------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------|------------------------------------------------|--|--|
|          | Read                           | SMCR1_ | SMCR1_                                                                                                                                                                                                                                                                                                                                                                                                                                            | SMCR1_I                                                                                                                                                                    | SMCR1_I                                                                                                                                                                 | SMCR1_                                                                                                         | SMCR1_                                                                                | SMCR1_                                                                | SMCR1_TX                                       |  |  |
| 7F67H    | Write                          | ACKEN  | CLKSEL                                                                                                                                                                                                                                                                                                                                                                                                                                            | NTEN                                                                                                                                                                       | NT                                                                                                                                                                      | TXCLK3                                                                                                         | TXCLK2                                                                                | TXCLK1                                                                | CLK0                                           |  |  |
|          | Reset                          | 0      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                          | 0                                                                                                                                                                       | 0                                                                                                              | 0                                                                                     | 0                                                                     | 0                                              |  |  |
|          | Symbol<br>SMCRn_AC<br>SMCRn_CL | KSEL   | FunctionAcknowledge enable bit (for SST79LF008 operation as a receiver) (n = 0-1)1: Enable ACK generation (SDAn is driven low during ACK cycle)0: Disable ACK generation (SDAn is not driven = SDAn "floats" during ACK cycle)SCL clock prescaler control (n = 0-1)1: $F_{PSCL} = F_{CCLK}/256$ 0: $F_{PSCL} = F_{CCLK}/16$ $F_{CCLK} = 8051$ core clock frequencySMBus controller Interrupt Enable bit (must be always set for normal operation— |                                                                                                                                                                            |                                                                                                                                                                         |                                                                                                                |                                                                                       |                                                                       |                                                |  |  |
|          | SMCRn_IN                       |        | 1: Enat<br>0: Disa<br>SMBus<br>softwar<br>1: Inter<br>0: No ir<br>Events<br>When a<br>When a<br>SMBus<br>SMBus                                                                                                                                                                                                                                                                                                                                    | bled Interrup<br>bled Interrup<br>is interrupt per<br>rupt is pendi<br>interrupt pendi<br>that set SM<br>an 1-byte tra<br>a general ca<br>bus arbitratic<br>is clock selec | t<br>ending flag. T<br>0'. Writing '1<br>ing (SMBus )<br>ding<br>CR1_INT in<br>nsmission o<br>Il or a slave a<br>on fails<br>tion control (<br>ency = F <sub>PSCI</sub> | This bit is set<br>to this bit w<br>s stalled as<br>hardware in<br>r receiving o<br>address mat<br>for SST79LF | by hardward<br>ill be ignored<br>SCLn line is<br>clude:<br>peration is c<br>ch occurs | e, and cleare<br>d. (n = 0-1)<br>held low)<br>ompleted<br>on as a mas | ster) (n = 0-1)<br>(n = 0-1)<br>ot be set 000x |  |  |



# 13.5.3 Multi-Master Bus Control / Status Register 0 (SMSR0)

| Location |       | 7              | 6              | 5             | 4               | 3             | 2               | 1               | 0             |
|----------|-------|----------------|----------------|---------------|-----------------|---------------|-----------------|-----------------|---------------|
| 7F32H    | Read  | SMSR0<br>_MOD1 | SMSR0<br>_MOD0 | SMSR0<br>_BSY | SMSR0<br>_SEREN | SMSR0<br>_ARB | SMSR0<br>_ADDRS | SMSR0<br>_ADDR0 | SMSR0<br>_ACK |
|          | Write |                |                |               |                 | -             | -               | -               | -             |
|          | Reset | 0              | 0              | 0             | 0               | 0             | 0               | 0               | 0             |

Symbol

Not implemented

Function

# 13.5.4 Multi-Master Bus Control / Status Register 1 (SMSR1)

| Location |       | 7              | 6              | 5             | 4               | 3             | 2               | 1               | 0             |
|----------|-------|----------------|----------------|---------------|-----------------|---------------|-----------------|-----------------|---------------|
| 7F68H    | Read  | SMSR1<br>_MOD1 | SMSR1<br>_MOD0 | SMSR1<br>_BSY | SMSR1<br>_SEREN | SMSR1<br>_ARB | SMSR1<br>_ADDRS | SMSR1<br>_ADDR0 | SMSR1<br>_ACK |
|          | Write |                |                |               |                 | -             | -               | -               | -             |
|          | Reset | 0              | 0              | 0             | 0               | 0             | 0               | 0               | 0             |

| Symbol<br>-    | Function<br>Not implemented                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SMSRn_MOD[1:0] | SMBus controller mode selection bits (n = 0-1)<br>SMBus controller mode. Selection as a function of SMSRn_MOD bits.<br>00 Slave receive mode<br>01 Slave transmit mode<br>10 Master receive mode<br>11 Master transmit mode<br>Normally these bits should be modified by software only when SMBus is idle. If<br>they are modified during data transfer, unexpected results could occur. One<br>exception is when MODE[1:0] is changed in order to generate a REPEATED                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| SMSRn_BSY      | <ul> <li>START condition after the last byte of the current transaction is received or transmitted.</li> <li>Both SMSRn_MOD0 and SMSRn_MOD1 bits are cleared by hardware automatically when:</li> <li>1) SMBus STOP condition is detected</li> <li>2) When SEREN bit is cleared</li> <li>3) SMBus arbitration failure is detected</li> <li>SMSRn_MOD0 bit is also set/cleared by hardware equal to the value of R/W# bit of the address phase, when SMBus controller is in slave mode. (n = 0-1)</li> <li>When read, this bit indicates the bus busy status (SMBus is busy between START</li> </ul>                                                                                                                                                                                                                                                                                                              |
|                | <ul> <li>and STOP conditions). When written to, this bit controls generation of START and STOP conditions for SMBus controller in master mode.</li> <li>1: When read: the bus is busy</li> <li>When written: START condition is generated, regardless of current SMBus busy status</li> <li>0: When read: the bus is not busy</li> <li>When written, STOP condition is generated only if SMBus was already busy. To generate START condition when bus is idle (BSY='0'), software should write '1' to SEREN, SMSRn_MOD1, and BSY bits simultaneously. To generate a REPEATED START current when bus is already busy (BSY='1'), software should write '1' to release the bus. To generate a STOP condition when bus is already busy (BSY='1') software should write '1' to bits SEREN and SMSRn_MOD1 while writing '0' to BSY bit simultaneously, and then clear INT bit to release the bus. (n = 0-1)</li> </ul> |



| SMSRn_SEREN | SMBus Serial output Enable bit                                                                                                                                                                                                   |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 1: Enable SMBus Receive/Transmit over SDAn and SCLn                                                                                                                                                                              |
|             | 0: Disable SMBus Receive/Transmit: MOD[1:0] are cleared, SDAn, SCLn are floated                                                                                                                                                  |
|             | The order of floating SDAn and SCLn is as follows: SCLn floats first, then SDAn floats.                                                                                                                                          |
|             | Therefore, disabling serial outputs when SST79LF008 is a transmitter may create a STOP condition on the bus if the last transmitted data bit was '0'. ( $n = 0-1$ )                                                              |
| SMSRn_ARB   | Arbitration status flag                                                                                                                                                                                                          |
|             | 1: Bus arbitration failed                                                                                                                                                                                                        |
|             | 0: No bus arbitration failure detected                                                                                                                                                                                           |
|             | This bit is automatically cleared when START/STOP condition is detected. $(n = 0.1)$                                                                                                                                             |
| SMSRn ADDRS | Slave Address match status                                                                                                                                                                                                       |
| —           | 1: Received slave address matches the address value in SAR                                                                                                                                                                       |
|             | 0: No slave address match detected                                                                                                                                                                                               |
|             | Both ARB and ADDRS bits will be set if arbitration failed during address phase, and address sent by the other master matches SAR setting. This bit is automatically cleared when START/STOP condition is detected. ( $n = 0-1$ ) |
| SMSRn_ADDR0 | Broadcast Address match status flag                                                                                                                                                                                              |
|             | 1: Received slave address is the broadcast address 00H                                                                                                                                                                           |
|             | 0: No broadcast address match is detected                                                                                                                                                                                        |
|             | Both ARB and ADDRS bits will be set if arbitration failed during address phase,                                                                                                                                                  |
|             | and address sent by the other master is the broadcast address. This bit is                                                                                                                                                       |
|             | automatically cleared when START/STOP condition is detected. ( $n = 0-1$ )                                                                                                                                                       |
| SMSRn_ACK   | Last-received bit status flag ( $n = 0-1$ )                                                                                                                                                                                      |
|             | 1: Last-received bit is '1' (ACK was not received)                                                                                                                                                                               |
|             | 0: Last-received bit is '0' (ACK was received)                                                                                                                                                                                   |

# 13.6 Multi-master Bus Address and Data Shift Registers

The SMBus address register is used to store the slave address of the respective SMBus controller.

### 13.6.1 Multi-Master Bus Address Register 0 (SAR0)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0 |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|---|
|          | Read  | SAR0_7 | SAR0_6 | SAR0_5 | SAR0_4 | SAR0_3 | SAR0_2 | SAR0_1 | - |
| 7F33H    | Write |        |        |        |        |        |        |        |   |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | Х |

### 13.6.2 Multi-Master Bus Address Register 1 (SAR1)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0 |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|---|
|          | Read  | SAR1_7 | SAR1_6 | SAR1_5 | SAR1_4 | SAR1_3 | SAR1_2 | SAR1_1 | - |
| 7F69H    | Write |        |        |        |        |        |        |        |   |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | х |

| Symbol    | Function                                                                                                                                                                                                                                        |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -         | Not Implemented                                                                                                                                                                                                                                 |
| Х         | Not defined                                                                                                                                                                                                                                     |
| SARn[7:1] | These bits holds the 7-bit slave address of the respective SMBus controller in the slave mode, they are compared with the data received from the master in the address phase.                                                                   |
|           | When address match is detected slave address match ADDRS bit, and SMBus pending interrupt INT bit will be both set. This register can only be written when SEREN = 0. When SAR is read, it always return previously written data. ( $n = 0-1$ ) |



The SMBus transmit/receive data register acts as a serial shift register and read buffer for interfacing with the SMBus. This register performs all read and write operation from/to the SMBus. In the receiver mode, the SMBus data is shifted into the data register until the acknowledge phase. Further reception of data is inhibited (SCL held low) until

the interrupt pending bit INT is cleared. In the transmitter mode, if the SEREN bit is set, the data is transmitted to the SMBus as soon as it is written to the data register. Further transmission of data is inhibited (SCL held low) until the interrupt pending bit INT is cleared.

### 13.6.3 Multi-Master Bus Transmit / Receive Data Shift Register 0 (SDSR0)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | SDSR0_7 | SDSR0_6 | SDSR0_5 | SDSR0_4 | SDSR0_3 | SDSR0_2 | SDSR0_1 | SDSR0_0 |
| 7F34H    | Write |         |         |         |         |         |         |         |         |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

#### 13.6.4 Multi-Master Bus Transmit / Receive Data Shift Register 1 (SDSR1)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | SDSR1_7 | SDSR1_6 | SDSR1_5 | SDSR1_4 | SDSR1_3 | SDSR1_2 | SDSR1_1 | SDSR1_0 |
| 7F6AH    | Write |         |         |         |         |         |         |         |         |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

SDSRn[7:0]

#### Function

Data shift register (n = 0-1)

When written to, transmit data to the SMBus provided SEREN = 1 (write is ignored if SEREN = 0). When read, returns the latched value received from SMBus during the last read operation.

In address phase of master mode for SMBus controller 0 (controller 1) bit SDSR0 in SDSR0 (SDSR1) register is equal to the inverse of SMSRn\_MOD0 bit in the respective SMSR0 (SMSR1) register. In other words, if it is master transmit mode, then SDSR0 equals to '0'; if it is master receive mode, then SDSR0 equals to '1'.



# 13.7 SMBus Switch Control and Line Status Registers

The SMBus Switch Control register is used to enable/disable both SMBus controllers, as well as to control the SMBus multiplexer, as shown on Figure 13-1. The SMBus Line status register is used to monitor the SMBus line status.

| Location |                                                                  | 7      | 6                             | 5                                                                                                     | 4                               | 3             | 2             | 1             | 0          |  |  |  |
|----------|------------------------------------------------------------------|--------|-------------------------------|-------------------------------------------------------------------------------------------------------|---------------------------------|---------------|---------------|---------------|------------|--|--|--|
|          | Read                                                             | SM1_EN | SM0_EN                        | -                                                                                                     | -                               | -             | P1_SEL        | UART_S        | CHSEL1     |  |  |  |
| 7F89H    | Write                                                            |        |                               |                                                                                                       |                                 |               |               | М             |            |  |  |  |
|          | Reset                                                            | 0      | 0                             | Х                                                                                                     | Х                               | Х             | 0             | 0             | 1          |  |  |  |
|          | Symbol                                                           |        | Function                      | Function                                                                                              |                                 |               |               |               |            |  |  |  |
|          | -                                                                |        | Not Imp                       | Not Implemented                                                                                       |                                 |               |               |               |            |  |  |  |
|          | Х                                                                |        | Not def                       | Not defined                                                                                           |                                 |               |               |               |            |  |  |  |
|          | SM1_EN                                                           |        | SMBus                         | controller 1                                                                                          | Enable bit                      |               |               |               |            |  |  |  |
|          | 1: SMBus controller 1 is enabled                                 |        |                               |                                                                                                       |                                 |               |               |               |            |  |  |  |
|          | 0: SMBus controller 1 is disabled and reset to the default state |        |                               |                                                                                                       |                                 |               |               |               |            |  |  |  |
|          | SM0_EN                                                           |        |                               | controller 0                                                                                          |                                 | al            |               |               |            |  |  |  |
|          |                                                                  |        |                               |                                                                                                       | r 0 is enable<br>r 0 is disable |               | to the defaul | lt etato      |            |  |  |  |
|          | P1_SEL                                                           |        |                               | 0: SMBus controller 0 is disabled and reset to the default state<br>Port1/GPI086-GPI093 Selection bit |                                 |               |               |               |            |  |  |  |
|          |                                                                  |        | 1: Select 8051 Port1 function |                                                                                                       |                                 |               |               |               |            |  |  |  |
|          |                                                                  |        |                               |                                                                                                       | PIO86-GPIC                      | 93 function   |               |               |            |  |  |  |
|          | UART SM                                                          |        | UART a                        | and SMBus                                                                                             | Channel 1 S                     | election bit  |               |               |            |  |  |  |
|          | _                                                                |        | 1: UAR                        | T RXD/TXD                                                                                             | function is s                   | selected as a | lternate fun  | ction for GPI | 053/GPI054 |  |  |  |
|          |                                                                  |        | 0: SDA                        | 1/SCL1 fund                                                                                           | ction is selec                  | ted as altern | ate function  | for GPIO53/   | GPIO54     |  |  |  |
|          | CHSEL1                                                           |        |                               |                                                                                                       | for SMBus c                     |               |               |               |            |  |  |  |
|          |                                                                  |        |                               |                                                                                                       |                                 |               |               | lriven by the | SMBus      |  |  |  |
|          |                                                                  |        |                               |                                                                                                       | and SDA2 pi                     |               |               | lrivon hv tho | SMBuc      |  |  |  |
|          |                                                                  |        |                               |                                                                                                       | and SDA1 pi                     |               |               | lriven by the | Sividus    |  |  |  |
|          |                                                                  |        | 0011101                       | 5. 1. OOL10                                                                                           |                                 |               |               |               |            |  |  |  |

### 13.7.1 SMBus Switch Control Register (SSCR)

### 13.7.2 SMBus Line Status Register (SLSR)

| Location |            | 7 | 6 | 5    | 4    | 3    | 2    | 1    | 0    |
|----------|------------|---|---|------|------|------|------|------|------|
|          | Read       | - | - | SCL2 | SDA2 | SCL1 | SDA1 | SCL0 | SDA0 |
| 7F88H    | Write      |   |   | -    | -    | -    | -    | -    | -    |
|          | Reset      | Х | Х | SCL2 | SDA2 | SCL1 | SDA1 | SCL0 | SDA0 |
|          | O. make al |   | E |      |      |      |      |      |      |

| Symbol | Function        |
|--------|-----------------|
| -      | Not implemented |
| Х      | Not defined     |

# **13.8 SMBus Operations**

After the SST79LF008 chip resets, both SMBus controllers are disabled. The 8051 firmware can enable each controller and configure SMBus channels via SSCR, GPIODSEL, and GPIOGSEL registers. The firmware can also specify the SMBus clock frequency and enable SMBus interrupts

### 13.8.1 Master Transmit Mode

In Master Transmit Mode, the master addresses the slave by sending the slave address, then the master will transmit data to the slave, and terminates the transfer after all data in SMCR0 or SMCR1 registers, and load slave addresses to the respective SAR0 or SAR1 registers. Then SST79LF008 is ready for SMBus transmit/receive transactions—a typical example is described in Figure 13-5.

has been transmitted.



# Mobile Platform Controller 8 Mbit LPC Firmware Flash SST79LF008

### Advance Information



FIGURE 13-5: SMBus Master Transmit Mode Operation

Figure 13-5 illustrates interaction between 8051 firmware and SMBus controller hardware in Master Transmit mode:

### Master Transmit Mode

- 1. Write D0H to SMSR. This presets the SMBus controller for Master Transmit mode.
- Write a 7-bit slave address to SDSR[7-1], and '0' to SDSR[0] (R/W# bit). The R/W# bit determines the direction of the transfer—if R/W# = 0 then the master will send data to the slave. Set the BSY bit in SMSR register. SMBus controller will generate a START condition and automatically send SDSR data over the SMBus.
- 3. The hardware completes transmission of eight data bits, receives the ninth bit during ACK clock period, and sets interrupt pending—keeping SMBus on hold and allowing the software to process the transfer results and check errors.

Note that in the case of successful transmission, allowing that arbitration has not failed, the slave is expected to send back an ACK to the master lowering the SDAn line during ACK clock.

4. Check for more data to transfer. If the master has more data to transfer, the software will write the next data byte to SDSR and clear the interrupt pending bit in SMCR. This causes the data in SDSR to be sent automatically over the SMBus by controller hardware and returns to Step 3.

If the master has no data to transfer, the software will clear the BSY bit in SMSR and clear the interrupt pending bit in SMCR. The controller hardware will generate a STOP condition and release the SMBus lines which completes the transaction.



#### 13.8.2 Master Receive Mode

In Master Receive Mode, the master addresses the slave by sending the slave address. After which, the master will receives data from the slave and then terminates the transfer after all data has been received.



FIGURE 13-6: SMBus Master Receive Mode Operation



Figure 13-6 illustrates interaction between 8051 firmware and SMBus controller hardware in Master Receive mode:

### Master Receive mode:

- 1. Write 90H to SMSR. This will preset SMBus controller for Master Receive mode.
- 2. Write a 7-bit slave address to SDSR[7-1], and '1' to SDSR[0] (R/W# bit). The R/W# bit determines the direction of the transfer—if R/W# = 1 then the master will receive data from the slave. Set the BSY bit in SMSR register. SMBus controller will generate a START condition and automatically send SDSR data over the SMBus.
- 3. The hardware completes transmission of eight data bits, receives the ninth bit during ACK clock period, and sets interrupt pending. This keeps SMBus on hold and allows the software to process the transfer results and check errors. Note that in the case of successful transmission, allowing that arbitration has not failed, the slave is expected to send back an ACK to the master lowering the SDAn line during ACK clock.
- 4. Determine whether the next transfer is the last data byte to transfer from the slave. If not, set the ACK enable bit and clear the interrupt pending bit in SMCR to release the SMBus allowing the slave to send the next data byte to the master. Proceed to Step 5 to finish receiving the next data byte.

If yes, indicated by only one byte remaining, clear the ACK enable bit and clear the interrupt pending bit in SMCR. This releases the SMBus allowing the slave to send the last data byte to the master. Proceed to Step 7 to complete receiving the last data byte.

- 5. The hardware completes receipt of eight data bits, then sends ninth bit during ACK clock period, and sets interrupt pending. This keeps SMBus on hold and allows the software to read the received byte. The data sent in ACK clock period depends on the value of ACKEN bit in SMCR register. If ACKEN bit is set, then ACK is generated automatically— SDAn is '0' in the ACK clock period.
- 6. Read the received data byte from SDSR and return to Step 4.
- 7. The hardware completes receipt of eight data bits, sends ninth bit during ACK clock period, and sets interrupt pending. This keeps SMBus on hold and allows the software to read the received byte. The data sent in ACK clock period depends on the value of ACKEN bit in SMCR register. If ACKEN bit is cleared, then NACK is generated automatically—SDAn is floating = '1' in ACK clock period.
- 8. Read the last received data byte from SDSR, clear the BSY bit in SMSR, and then clear the interrupt pending bit in SMCR. The controller hardware will generate a STOP condition and release the SMBus channel which completes the transaction.



### 13.8.3 Slave Transmit Mode

In the Slave Transmit Mode, the slave compares the received address with SAR register contents. If the received address and SAR register matches, the slave will transmit data to the master until the master stops the transaction.



FIGURE 13-7: SMBus Slave Transmit Mode Operation



Figure 13-7 illustrates interaction between 8051 firmware and SMBus controller hardware in Slave Transmit mode:

### Slave Transmit mode:

- 1. Write 10H to SMSR. This will preset SMBus controller for Slave Receive mode.
- 2. The hardware detects the START bit, automatically sets the BSY bit, and receives the data byte from the bus.

Then the hardware compares the value of SAR[7:1] with the data received in the SDSR[7:1]: If it matches, proceed to Step 3 to complete the address phase.

If not, detect STOP condition when generated by the master. The STOP condition clears BSY bit in the hardware and completes the transaction.

3. The hardware sends ACK and sets the interrupt pending bit to keep SMBus on hold. If the value of the R/W# bit from the master (=SDSR[0]) is '1', then SMSRn\_MOD0 is set and SMBus controller automatically switches to Slave Transmit mode. For example, when the master requires data from the slave.

- 4. Write data to be transmitted to the SDSR and clear the interrupt pending bit in SMCR. This causes the data in SDSR to be sent automatically over SMBus by controller hardware.
- 5. The hardware completes transmission of eight data bits, receives the ninth bit during ACK clock period, and sets interrupt pending. This keeps SMBus on hold and allows the software to process the transfer results and check errors. Note that in the case of successful transmission, allowing that arbitration has not failed, the master is expected to send back an ACK to the slave lowering the SDAn line during ACK clock—except for the last byte of the transaction.
- 6. Determine whether the last data byte has transmitted.

If no, ACK was received. Return to Step 4 to start the next data byte transmit cycle. If yes, NACK was received. Clear SMSRn\_MOD0 bit in SMSR register and clear the interrupt pending bit in SMCR. This will release the bus so that the master will be able to generate a STOP condition which clears BSY bit in hardware and completes the transaction.



### 13.8.4 Slave Receive Mode

In Slave Receive Mode, the slave compares the received address with the SAR register contents. If they match, the slave will receive data from the master until the master stops the transaction.



FIGURE 13-8: SMBus Slave Receive Mode Operation



Figure 13-8 illustrates interaction between 8051 firmware and SMBus controller hardware in Slave Receive mode:

### Slave Receive mode:

- 1. Write 0x10 to SMSR. This will preset SMBus controller for Slave Receive mode.
- 2. The hardware detects the START bit, automatically sets the BSY bit, and receives the data byte from the bus.

Then the hardware compares the value of SAR[7:1] with the data received in the SDSR[7:1]: If it matches, proceed to Step 3 to complete the address phase.

If not, detect STOP condition when generated by the master. The STOP condition clears BSY bit in the hardware and completes the transaction.

3. The hardware sends ACK and sets the interrupt pending bit to keep SMBus on hold. If the value of the R/W# bit from the master (=SDSR[0]) is '0', then SMSRn\_MOD0 bit in SMSR is kept unchanged and SMBus controller is in Slave Receive Mode. This happen, for example, when the master sends data to the slave.

- 4. Set ACKEN bit and clear the interrupt pending bit to release the SMBus, allowing the master to send data byte to the slave.
- 5. If the master device stops the transaction, the hardware detects a STOP condition and clears BSY bit.

OR

If the master device continues sending data, the hardware completes transmission of eight data bits, receives the ninth bit during ACK clock period, and sets interrupt pending. This keeps SMBus on hold and allows the software to read the received byte. The data sent in ACK clock period depends on the value of ACKEN bit in SMCR register. If ACKEN bit is set, then ACK is generated automatically (SDAn is '0' in ACK clock period.

- 6. Determine whether the STOP bit is detected (BSY bit is cleared.)
  If no STOP condition is detected, go to Step 7 to read data.
  If master generates a STOP condition, then the transaction is complete.
- 7. Software reads the received data in SDSR and returns to Step 4 to start the next data byte receiving cycle.



#### 13.8.5 Switching Between Master Transmit and Master Receive Modes

When switching from Master Transmit to Master Receive mode, a REPEATED START condition precedes the switch. This differs from most general mode switches when the switch occurs after a STOP condition and while the SMBus is idle. For example, when in Transmit Mode and after all necessary data is transmitted, the software writes a 7-bit slave address to SDSR[7:1] and '1' to the SDSR[0] (R/ W# bit). The software then clears the SMSRn\_MOD0 bit in SMSR and clears the interrupt pending bit in SMCR to release the SMBus, which causes the controller hardware to generate a REPEATED START condition and the SMBus operation continues in Master Receive mode, see Figure 13-9. Refer to Section 13.5 for Master Transmit details and Section 13.6 Master Receive details.



FIGURE 13-9: SMBus Transmit/Receive Mode Switch



Figure 13-9 illustrates interaction between 8051 firmware and SMBus controller hardware in Master Transmit to Master Receive mode switch:

# Master Transmit Mode to Master Receive Mode Switch:

- 1. Write D0H to SMSR. This will preset SMBus controller for Master Transmit mode.
- Write a 7-bit slave address to SDSR[7-1] and '0' to SDSR[0] (R/W# bit). The R/W# bit determines the direction of the transfer. For example, if R/W# = '0', then the master sends data to the slave. Set the BSY bit in the SMSR register. SMBus controller generates a START condition and automatically sends SDSR data over the SMBus.
- 3. The hardware completes the transmission of eight data bits, receives the ninth bit during ACK clock period, and sets the interrupt pending. This keeps SMBus on hold and allows the software to process the transfer results and check errors.

- **Note:** In the case of a successful transmission, allowing that arbitration has not failed, the slave is expected to send back an ACK to the master—lowering the SDAn line during ACK clock.
- 4. Check for more data transfer.

If the master has more data to transfer, the software will write the next data byte to SDSR and clear the interrupt pending bit in SMCR. This causes the data in SDSR to be sent automatically over the SMBus by controller hardware and returns to Step 3.

If the master has no data to transfer, the software will write a 7-bit slave address to SDSR[7-1] and '1' to SDSR[0] (R/W# bit). The R/W# bit determines the direction of the transfer. For example, if R/W# = '1', then the master receives data from the slave. The software clears the SMSRn\_MOD0 bit in SMSR and clears the interrupt pending bit in SMCR to release the SMBus. The controller hardware will generate a REPEATED START condition and the SMBus operation continues in Master Receive mode, see Figure 13-9. For Master Transmit details, see Section 13.5 For Master Receive details, see Section 13.6.



### 14.0 PS/2 INTERFACE

### 14.1 PS/2 Features

- IBM PS/2 standard compliant
- Three independent PS/2 channels
- PS/2 hardware state machine for each channel
- Embedded transfer time-out detection
- Support both polling and interrupt driven operation
- Optional support for software bit-banging control
- Wake up from Idle and Power Down modes

### 14.2 PS/2 Channels

The PS/2 interface is an industry standard interface for PC communication to an external keyboard, mouse, internal pointing device, and other PS/2 compatible auxiliary devices. The SST79LF008 provides three identical PS/2 serial channels that are used to interface directly with PS/2 peripherals (see Figure 14-1).

Each PS/2 channel consists of two signal lines: PS/2 clock (PSCLKn, n=0-2) and PS/2 data (PSDATn, n=0-2). The respective I/O buffers must have open drain outputs, so that either the SST79LF008 PS/2 host, or the PS/2 device can control PS/2 signals during bidirectional communications. However, the clock for both transmit and receive protocols is always generated by the PS/2 peripheral device. The PS/2 lines are connected externally to the positive 5V source via pull-up resistors (typically 10 KOhm).

The on-chip PS/2 hardware state machine for each channel supports standard IBM PS/2 compliant receive and transmit protocols. Embedded PS/2 time-out detection frees core timers from PS/2 interface control. For any PS/2 transfer, start-bit interrupt as well as transfer completion interrupt are generated.

The 8051 core controls PS/2 channels via memory mapped configuration registers. The PS/2 hardware state machine may be disabled. In this case, the respective PS/2 channel can operate in software controlled bit-banging mode. This allows communication to peripheral devices, which do not meet the standard PS/2 protocol timing.





Operations of all PS/2 channels are independent except for the following scenario. If PS/2 hardware state machine is enabled—the PS2CRn\_PS2\_EN (n=0-2) bit is set,see Section 14.4.3—only the channel which detects the start bit first is selected for receiving. The transfer over all other enabled channels is automatically inhibited by resetting the respective control registers to the default values, which results in forcing low state on the PS/2 clock lines. Software can set the PS2CRn\_PS2\_EN (n = 0-2) bits for the inhibited channels at any time, but hardware will hold clock lines low until the active channel completes receiving data and active PS/2 channel interrupt is cleared. If multiple start bits are detected at the same time from more than one channel, the lower order channel will be selected. If PS/2 hardware state machine is disabled, the PS2CRn\_PS2\_EN (n = 0-2) bit is cleared. It is the responsibility of the firmware to select the active receiving channel. The selection of transmitting channel is always controlled by the firmware.



### 14.3 PS/2 Protocol Overview

The PS/2 protocol data stream transmits to/from the PS/2 device via each PS/2 channel consists of 11 bits: start bit (always 0), eight data bits (with least significant bit first), a parity bit (always odd parity), and a stop bit (always 1). The transmit protocol also includes a line control bit that serves as PS/2 device acknowledgement.

Normally the PS/2 interface is in the idle state with both clock and data lines floating (i.e., pulled-up high by external resistors). The receive start bit is created by a high to low transition of the clock signal PSCLKn while the data signal PSDATn is held low as shown in Figure 14-2. After the start bit, the PS/2 interface is in the active receive state. In this state, the PS/2 peripheral device generates clock signal PSCLKn and sends PS/2 data on the data line PSDATn. The SST79LF008 PS/2 host samples each data bit on the falling edge of the clock. The eight data bits are followed by the odd parity bit and a stop bit which completes the transfer.

The PS/2 transmit mode is initiated when the PS/2 host switches the PS/2 channel into the transmit idle, or requestto-send state. In this state the respective clock line PSCLKn is high while the data line PSDATn is forced low by the SST79LF008. In response the PS/2 device generates a falling edge on the clock line while the data signal PSDATn is still low. This indicates the start bit for the transmission as shown in Figure 14-3. After the start bit, the PS/2 interface is in the active transmit state. In this state, the PS/2 peripheral device generates clock signal PSCLKn, but the PS/2 data on the data line PSDATn is sent by the PS/2 host. Each data bit is shifted out of the SST79LF008 host on the falling edge of the clock. The eight data bits are followed by an odd parity bit and a stop bit. Then, the PS/2 device forces data line low and generates one more clock, called line-control bit, to complete the transfer.

When the PS/2 host is receiving data from the PS/2 peripheral device the data stream can be aborted by forcing the clock line of the respective channel low. If the PS/2 abort occurs prior to the falling edge of the 10<sup>th</sup> clock, then the received data is discarded and the peripheral device will retransmit it later. If the PS/2 abort occurs following the falling edge of the 10th clock, then the received data must be accepted by the host, as the peripheral device will not retransmit it.

See IBM Personal System/2 Hardware Interface Technical Reference for more details on PS/2 protocol.



FIGURE 14-2: PS/2 Receive Protocol



FIGURE 14-3: PS/2 Transmit Protocol



control register and the PS2STSn XMIT IDLE bit in

the PS2 status register, or Alternate PS2 status regis-

ter are set. If any one of the three bits, are cleared, PS2CRn\_PS2\_EN, PS2\_T/R, or PS2STSn\_XMIT\_IDLE,

When PS/2 transmission is initiated, the PS2STSn XMIT

IDLE, n=0-2, and APS2STSn\_XMIT\_IDLE, n=0-2, bits are automatically cleared. After successful completion of the

transmission, the PS2STSn XMIT IDLE and APS2STSn

XMIT IDLE bits are set, and the PS2CRn PS2 T/R bit is

cleared in hardware. This automatically switches the

respective PS/2 channel into the receive mode.

then the data written to the transmit register is ignored.

### 14.4 PS/2 MMCRs

There are five MMC registers associated with each PS/2 channel: PS/2 transmit register, PS/2 receive register, PS/2 control register, PS/2 status, and PS/2 alternate status registers. The transmit and receive registers are located at the same address. There are also two registers common for all channels: PS/2 time-out control register and PS/2 status 2 register.

### 14.4.1 PS/2 Transmit Registers

PS/2 transmit registers are write-only registers. To transmit a data byte over the PS/2 interface by the PS/2 hardware, it must be written while the PS2CRn\_PS2\_EN, n=0-2,and PS2CRn\_PS2\_T/R, n=0-2 bits in the PS/2

#### 14.4.1.1 PS/2 Transmit Register 0 (PS2TX0)

7 5 2 Location 6 4 3 1 0 Write PS2TX0 PS2TX0 PS2TX0 PS2TX0 PS2TX0 PS2TX0 PS2TX0 PS2TX0 7F41H 7 6 5 4 З 2 1 0 0 0 0 0 0 0 0 0 Reset

### 14.4.1.2 PS/2 Transmit Register 1 (PS2TX1)

| Location |       | 7           | 6           | 5           | 4           | 3           | 2           | 1           | 0           |
|----------|-------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
| 7F45H    | Write | PS2TX1<br>7 | PS2TX1<br>6 | PS2TX1<br>5 | PS2TX1<br>4 | PS2TX1<br>3 | PS2TX1<br>2 | PS2TX1<br>1 | PS2TX1<br>0 |
|          | Reset | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           |

### 14.4.1.3 PS/2 Transmit Register 2 (PS2TX2)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| 754011   | Write | PS2TX2 |
| 7F49H    |       | _/     | _6     | _5     | _4     | _3     | _2     | _1     | _0     |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol PS2TXn[7:0] Function

PS/2 transmit, write only, register bits (n = 0-2)

#### 14.4.2 PS/2 Receive Registers

PS/2 receive registers are read-only registers. When the PS2CRn\_PS/2\_EN (n = 0-2) bit is set and the PS2CRn\_ PS/2\_T/R (n = 0-2) is cleared, the PS/2 hardware state machine places data, received from the peripheral device, into the receive register at the end of a successful receipt of data. At the same time, the respective PS/2 clock line is forced low by the PS/2 hardware to inhibit any further PS/2 transmission, and the PS2STSn\_RDATA\_RDY or APS2STSn\_RDATA\_RDY (n = 0-2) bits inthe status register or alternate status register are set indicating that data is ready to be read by the software. Thus, data received over PS/2 interface can be read from the PS/2 receive register only when the PS2STSn\_ RDATA\_RDY or APS2STSn\_RDATA\_RDY (n=0-2) bits are set. Reading this register while the PS2STSn\_RDATA\_ RDY or APS2STSn\_RDATA\_RDY (n=0-2) bits are cleared always returns 0FFH.

The PS2STSn\_RDATA\_RDY or APS2STSn\_RDATA\_ RDY bits must be cleared by reading the status register in order to allow the next PS/2 data reception or transmission.



### 14.4.2.1 PS/2 Receive Register 0 (PS2RCV0)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | PS2RCV0 |
| 7F41H    |       | _7      | _6      | _5      | _4      | _3      | _2      | _1      | _0      |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

### 14.4.2.2 PS/2 Receive Register 1 (PS2RCV1)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | PS2RCV1 |
| 7F45H    |       | _7      | _6      | _5      | _4      | _3      | _2      | _1      | _0      |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

### 14.4.2.3 PS/2 Receive Register 2 (PS2RCV2)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | PS2RCV2 |
| 7F49H    |       | _7      | _6      | _5      | _4      | _3      | _2      | _1      | _0      |
|          | Reset | 1       | 1       | 1       | 1       | 1       | 1       | 1       | 1       |

Symbol

Function

PS2RCVn[7:0]

PS/2 receive, read only, register bits (n = 0-2)

### 14.4.3 PS/2 Control Registers

### 14.4.3.1 PS/2 Control Register 0 (PS2CR0)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | PS2CR0_ |
| 7F42H    | Write | WR_CLK  | WR_DATA | STOP1   | STOP0   | PARITY1 | PARITY0 | PS2_EN  | PS2_T/R |
|          | Reset | 0       | 1       | 0       | 0       | 0       | 0       | 0       | 0       |

### 14.4.3.2 PS/2 Control Register 1 (PS2CR1)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | PS2CR1_ |
| 7F46H    | Write | WR_CLK  | WR_DATA | STOP1   | STOP0   | PARITY1 | PARITY0 | PS2_EN  | PS2_T/R |
|          | Reset | 0       | 1       | 0       | 0       | 0       | 0       | 0       | 0       |



### 14.4.3.3 PS/2 Control Register 2 (PS2CR2)

| Location |                           | 7                 | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 5                                                                                                                                                                                                                                                                                                                                                           | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3                                                                                                                                                                                                                                                                | 2                                                                                                                                                                                                                                          | 1                                                                                                                                                                                                                         | 0                                                                                                                                                                 |  |  |
|----------|---------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7F4AH    | Read<br>Write             | PS2CR2_<br>WR_CLK | PS2CR2_<br>WR_DATA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | PS2CR2_<br>STOP1                                                                                                                                                                                                                                                                                                                                            | PS2CR2_<br>STOP0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PS2CR2_<br>PARITY1                                                                                                                                                                                                                                               | PS2CR2_<br>PARITY0                                                                                                                                                                                                                         | PS2CR2_<br>PS2_EN                                                                                                                                                                                                         | PS2CR2_<br>PS2_T/R                                                                                                                                                |  |  |
|          | Reset                     | 0                 | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                                                                                                           | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                          | 0                                                                                                                                                                                                                         | 0                                                                                                                                                                 |  |  |
|          | <b>Symbol</b><br>PS2CRn_W | /R_CLK            | PS/2 cl<br>When I<br>1: Floa<br>0: Drive<br>When I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Function<br>PS/2 clock line control bit (n = 0-2)<br>When PS2CRn_PS2_EN = 0 (bit-banging enabled)<br>1: Float the respective PS/2 channel's PSCLKn pin<br>0: Drive "low" the respective PS/2 channel's PSCLKn pin<br>When PS2CRn_PS2_EN = 1, this bit can be updated but has no effect on<br>PSCLKn pin. Reading this bit always returns the written value. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                            |                                                                                                                                                                                                                           |                                                                                                                                                                   |  |  |
|          | PS2CRn_W                  |                   | When I<br>1: = Flo<br>0: = Dri<br>When I<br>PSDAT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | PS/2 data line control bit (n = 0-2)<br>When PS2CRn_PS2_EN = 0 (bit-banging enabled)<br>1: = Float the respective PS/2 channel's PSDATn pin<br>0: = Drive "low" the respective PS/2 channel's PSDATn pin<br>When PS2CRn_PS2_EN = 1, this bit can be updated, but has no effect on<br>PSDATn pin. Reading this bit always returns the written value.         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                            |                                                                                                                                                                                                                           |                                                                                                                                                                   |  |  |
|          | PS2CRn_S                  | TOP[1:0]          | <ul> <li>PS/2 hardware state machine stop frame control bits. Valid only when</li> <li>PS2CRn_PS2_EN = 1. PS/2 transmit protocol with high level stop bit (n = 0-2)</li> <li>00: PS/2 receive protocol with high level stop bit (PS/2 standard)</li> <li>01: PS/2 receive protocol with low level stop bit</li> <li>10: PS/2 receive protocol stop bit level is ignored (data for stop bit clock is not checked, however, it is still counted as the 11<sup>th</sup> clock of the receiving data strea</li> <li>11: Reserved</li> </ul>                   |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                            |                                                                                                                                                                                                                           |                                                                                                                                                                   |  |  |
|          | PS2CRn_P                  | ARITY[1:0]        | <ul> <li>PS/2 hardware state machine parity frame control bits. Valid only when</li> <li>PS2CRn_PS2_EN = 1. (n = 0-2)</li> <li>00: PS/2 receive and transmit protocols with odd parity bit (PS/2 standard)</li> <li>01: PS/2 receive and transmit protocols with even parity bit</li> <li>10: PS/2 receive protocol parity bit level is ignored (data for parity bit clock is no checked, however, it is still counted as the 10th clock of the receiving data strea</li> <li>PS/2 transmit protocol with odd parity bit</li> <li>11: Reserved</li> </ul> |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                            |                                                                                                                                                                                                                           | ndard)<br>clock is not                                                                                                                                            |  |  |
|          | PS2CRn_P                  | S2_EN             | 1: Enat<br>receive<br>PS2CF<br>0: Disa<br>PSDAT<br>PS2CF<br>(A)PS2<br>When I<br>in recei<br>mode v<br>When I<br>accordi<br>hardwa<br><b>Note:</b> Ta<br>PS2CR<br>the 10 <sup>th</sup><br>If PS2C<br>receive                                                                                                                                                                                                                                                                                                                                               | ble PS/2 har<br>s or transmi<br>Rn_PS2_T/F<br>ble PS/2 hau<br>in lines unde<br>Rn_WR_DAT<br>STSn_RD_<br>S2CRn_PS<br>ve or transm<br>vith PS2CRn<br>PS2CRn_PS<br>ing to PS2C<br>ing to PS2C<br>ing to PS2C<br>ing to PS2C<br>ing to PS2C<br>ing to PS2C<br>clock in the<br>cabort a tran<br>n_PS2_EN<br>clock in the<br>cRn_PS2_E1<br>d data is sav          | ts data over<br>The bit.<br>Troware state<br>or software c<br>the bits in this<br>CLK flags in<br>S2_EN bit sw<br>nit mode dep<br>n_PS2_T/R<br>S2_EN bit sv<br>Rn_WR_CL<br>ad.<br>S2_EN bit so<br>Rn_WR_CL<br>ad.<br>S2_EN bit so<br>S2_EN bit so<br>S | machine. The<br>the respective<br>machine. Encontrol using<br>register as<br>the status re-<br>vitches from<br>ending on F<br>= 0).<br>vitches from<br>K and PS20<br>e PS/2 peripte<br>c cleared similar<br>ta stream (page<br>ed after the far<br>ever register | ne PS/2 harc<br>ve PS/2 char<br>nable bit-bar<br>PS2CRn_W<br>well as (A)P<br>egister.<br>'0' to '1', the<br>'S2CRn_PS<br>'1' to '0', the<br>CRn_WR_D/<br>heral, the PS<br>nultaneously<br>arity bit), and<br>alling edge o<br>(provided th | Iware autom<br>nnel depend<br>nging of PSC<br>/R_CLK and<br>S2STSn_RE<br>PS/2 hardwa<br>2_T/R bit (de<br>PS/2 lines a<br>ATA values, a<br>S2CRn_WR_<br>prior to the f<br>then held for<br>f the 10th clo<br>ere is no par | ing on the<br>CLKn and<br>D_DATA and<br>are is enabled<br>efault: receive<br>are set<br>and PS/2<br>CLK and<br>falling edge of<br>at least 100S.<br>ock, then the |  |  |



| Advance Information |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PS2CRn_PS2_T/R      | <ul> <li>PS/2 Channel Transmit/Receive control bit. Valid only when<br/>PS2CRn_PS2_EN = 1. (n = 0-2)</li> <li>1: Enable PS/2 channel to transmit data</li> <li>0: Enable PS/2 channel to receive data</li> <li><u>Transmit</u>: Setting the PS/2_T/R bit in software causes the PS/2 hardware to inhibit<br/>PS/2 interface (PSCLKn line is driven low and PSDATn line is floated). The<br/>channel is inhibited until the next write to the transmit register, which switches the<br/>PS/2 channel into request-to-send state (PSDATn line is driven low and after that<br/>the PSCLKn line is floated). In response, the PS/2 device starts transmission by<br/>generating PS/2 clock pulses. During the transmission, the peripheral device<br/>drives PSCLKn line and the PS/2 hardware drives PSDATn line until the stop bit is<br/>sent. Then the PS/2 device generates line control bit clock and data. The PS/2_T/<br/>R bit is automatically cleared if transmit time-out is detected, or by the 11th clock<br/>rising edge when the line control bit successfully completes the transmission. In<br/>the latter case the PS/2 channel hardware automatically switches into receive<br/>mode.</li> <li><u>Receive</u>: When PS2CRn_PS2_T/R bit is cleared in software or after successful<br/>transmission the PS/2 channel is in receive mode with PSCLKn and PSDATn lines<br/>floating and ready to automatically shift data from the peripheral PS/2 device.</li> <li>Note: The PS2CRn_PS2_T/R bit must not be cleared by software in the middle of<br/>the transmission. The PS2CRn_PS2_T/R bit is set after the 10th clock (parity bit). In this case the<br/>received data is discarded. If this bit is set after the 10th clock, the received data is<br/>saved in the receive register (provided no parity error), the<br/>(A)PS2STSn_RDATA_RDY bit is set, and PSCLKn line is forced low. Neither transmit<br/>nor receive operation is possible if any of the bits (A)PS2STSn_RDATA_RDY,<br/>(A)PS2STSn_T_TIMEOUT, or (A)PS2STn_R_TIMEOUT in the status register are<br/>set, because in these cases the channel's PSCLKn line will be held low until the sta-<br/>tus register is read by software.</li> </ul> |

#### 14.4.4 PS/2 Status Registers

There are six PS/2 status registers: one PS/2 Status Register and one Alternate PS/2 Status Register for each PS/2 channel. Reading the alternate status register, APS2STSn, does NOT clear the respective channel's interrupt sources and/or status bits. However, reading the status register, PS2STSn, clears PS/2 channel interrupt sources and the status bits PS2STSn\_FE/APS2STSn\_FE, n=0-2,

PS2STSn\_PE/APS2STSn\_PE, n=0-2, PS2STSn\_ RDATA\_RDY/APS2STSn\_RDATA\_RDY, n=0-2, PS2STSn \_T\_TIMEOUT/APS2STSn\_T\_TIMEOUT, n=0-2, PS2STSn\_R\_TIMEOUT/APS2STSn\_R\_TIMEOUT, n=0-2, PS2STSn\_TXSB/APS2STSn\_TXSB, n=0-2, and PS2STSn\_RX\_BUSY/APS2STSn\_RX\_BUSY, n=0-2, of the respective channel.

| 14.4.4.1 PS/2 Status Register 0 (PS2STS0) | 14.4 | 4.4.1 | PS/2 Stat | tus Regis | ster 0 (PS | S2STS0) |
|-------------------------------------------|------|-------|-----------|-----------|------------|---------|
|-------------------------------------------|------|-------|-----------|-----------|------------|---------|

| Location |       | 7        | 6        | 5         | 4         | 3        | 2        | 1         | 0         |
|----------|-------|----------|----------|-----------|-----------|----------|----------|-----------|-----------|
|          | Read  | PS2STS0_ | PS2STS0_ | PS2STS0_T | PS2STS0_  | PS2STS0_ | PS2STS0_ | PS2STS0_R | PS2STS0_R |
| 7F43H    |       | RD_CLK   | RD_DATA  | _TIMEOUT  | XMIT_IDLE | FE       | PE       | _TIMEOUT  | DATA_RDY  |
|          | Write | -        | -        | -         | -         | -        | -        | -         | -         |
|          | Reset | 0        | 1        | 0         | 1         | 0        | 0        | 0         | 0         |

### 14.4.4.2 PS/2 Status Register 1 (PS2STS1)

| Location |       | 7        | 6        | 5         | 4         | 3        | 2        | 1         | 0         |
|----------|-------|----------|----------|-----------|-----------|----------|----------|-----------|-----------|
|          | Read  | PS2STS1_ | PS2STS1_ | PS2STS1_T | PS2STS1_X | PS2STS1_ | PS2STS1_ | PS2STS1_R | PS2STS1_R |
| 7F47H    |       | RD_CLK   | RD_DATA  | _TIMEOUT  | MIT_IDLE  | FE       | PE       | _TIMEOUT  | DATA_RDY  |
|          | Write | -        | -        | -         | -         | -        | -        | -         | -         |
|          | Reset | 0        | 1        | 0         | 1         | 0        | 0        | 0         | 0         |



### 14.4.4.3 PS/2 Status Register 2 (PS2STS2)

| Location |       | 7        | 6        | 5         | 4         | 3        | 2        | 1         | 0         |
|----------|-------|----------|----------|-----------|-----------|----------|----------|-----------|-----------|
|          | Read  | PS2STS2_ | PS2STS2_ | PS2STS2_T | PS2STS2_X | PS2STS2_ | PS2STS2_ | PS2STS2_R | PS2STS2_R |
| 7F4BH    |       | RD_CLK   | RD_DATA  | _TIMEOUT  | MIT_IDLE  | FE       | PE       | _TIMEOUT  | DATA_RDY  |
|          | Write | -        | -        | -         | -         | -        | -        | -         | -         |
|          | Reset | 0        | 1        | 0         | 1         | 0        | 0        | 0         | 0         |

### 14.4.4.4 Alternate PS/2 Status Register 0 (APS2STS0)

| Location |       | 7        | 6        | 5         | 4         | 3        | 2        | 1         | 0         |
|----------|-------|----------|----------|-----------|-----------|----------|----------|-----------|-----------|
|          | Read  | APS2STS0 | APS2STS0 | APS2STS0_ | APS2STS0_ | APS2STS0 | APS2STS0 | APS2STS0_ | APS2STS0_ |
| 7FF7H    |       | _RD_CLK  | _RD_DATA | T_TIMEOUT | XMIT_IDLE | _FE      | _PE      | R_TIMEOUT | RDATA_RDY |
|          | Write | -        | -        | -         | -         | -        | -        | -         | -         |
|          | Reset | 0        | 1        | 0         | 1         | 0        | 0        | 0         | 0         |

### 14.4.4.5 Alternate PS/2 Status Register 1 (APS2STS1)

| Location |       | 7        | 6        | 5         | 4         | 3        | 2        | 1         | 0         |
|----------|-------|----------|----------|-----------|-----------|----------|----------|-----------|-----------|
|          | Read  | APS2STS1 | APS2STS1 | APS2STS1_ | APS2STS1_ | APS2STS1 | APS2STS1 | APS2STS1_ | APS2STS1_ |
| 7FF8H    |       | _RD_CLK  | _RD_DATA | T_TIMEOUT | XMIT_IDLE | _FE      | _PE      | R_TIMEOUT | RDATA_RDY |
|          | Write | -        | -        | -         | -         | -        | -        | -         | -         |
|          | Reset | 0        | 1        | 0         | 1         | 0        | 0        | 0         | 0         |

#### 14.4.4.6 Alternate PS/2 Status Register 2 (APS2STS2)

| Location |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 7                   | 6                    | 5                      | 4                      | 3               | 2               | 1                      | 0                      |  |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----------------------|------------------------|------------------------|-----------------|-----------------|------------------------|------------------------|--|
| 7FF9H    | Read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | APS2STS2<br>_RD_CLK | APS2STS2<br>_RD_DATA | APS2STS2_<br>T_TIMEOUT | APS2STS2_<br>XMIT_IDLE | APS2STS2<br>_FE | APS2STS2<br>_PE | APS2STS2_<br>R_TIMEOUT | APS2STS2_<br>RDATA_RDY |  |
|          | Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | -                   | -                    | -                      | -                      | -               | -               | -                      | -                      |  |
|          | Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0                   | 1                    | 0                      | 1                      | 0               | 0               | 0                      | 0                      |  |
|          | Symbol       Function         -       Not implemented         (A)PS2STSn_RD_CLK       PS/2 clock line status flag (n = 0-2)         This bit reflects the current state of the PSCLKn line. The RD_CLK flag or used in conjunction with PS2CRn_WR_CLK control bit for software bit-bit when PS2CRn_PS2_EN = 0. A high to low transition on PSCLKn pin cat the peripheral device will generate the following:         • PS2 channel interrupt request in the INTSRCB register when PS2CRn_PS2_EN = 0         • PS2 start bit interrupt request in the WSRCA register, regardless PS2CRn_PS2_EN value.         Note:For proper bit-banging operations the (A)PS2STSn_RDATA_RDY, (A)PS2STn_R_TIMEOUT, and (A)PS2STSn_T_TIMEOUT flags in this reg must be cleared. |                     |                      |                        |                        |                 |                 |                        |                        |  |
|          | <ul> <li>(A)PS2STSn_RD_DATA PS/2 data line status flag (n = 0-2)<br/>This bit reflects the current state of the PSDATn line. The (A)PS2STSn_RD_DATA flag can be used in conjunction with PS2CRn_WR_DATA control bit for software bit-banging when PS2CRn_PS2_EN= 0</li> <li>(A)PS2STSn_T_TIMEOUT Transmission Time-out flag (n = 0-2)<br/>This bit is set when PS2CRn_PS2_EN = 1, and one of the following conditions detected:</li> </ul>                                                                                                                                                                                                                                                                                                                     |                     |                      |                        |                        |                 |                 |                        |                        |  |



| avance information   |                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | <ul> <li>The transmission bit time (time between clock falling edges) exceeds<br/>300µs, if this time-out detection is enabled.</li> </ul>                                                                                                                                                                                                                                                       |
|                      | • The transmission start clock is not received within 25 ms of signaling a transmission request event (request-to-send state), if this time-out detection is enabled.                                                                                                                                                                                                                            |
|                      | • The time from the 1st (start) clock falling edge to the rising edge of the 11th clock (line control bit) exceeds 2 ms, if this time-out detection is enabled.                                                                                                                                                                                                                                  |
|                      | • The response start bit is not received within 25ms after successful com-<br>pletion of the transmission, if this time-out detection is enabled.                                                                                                                                                                                                                                                |
|                      | The channel's PSCLKn pin is pulled down in hardware after the (A)PS2STSn_T_TIMEOUT bit is set and will be held low until (A)PS2STSn_T_TIMEOUT is cleared by reading the status register in software.                                                                                                                                                                                             |
|                      | The PS/2 channel interrupt request is generated on the low to high transition of $(A)$ PS2STSn_T_TIMEOUT.                                                                                                                                                                                                                                                                                        |
| (A)PS2STSn_XMIT_IDLE | Transmitter idle status flag (n = 0-2)<br>This bit is cleared by writing to the transmit register when the channel's hardware is<br>in transmit mode (PS2CRn_PS2_EN = PS2CRn_PS2_T/R = 1). While<br>(A)PS2STSn_XMIT_IDLE = 0, the PS/2 hardware state machine is transmitting<br>data to the PS2 peripheral device.                                                                              |
|                      | <ul><li>This bit is set when one of the following events occurs:</li><li>The rising edge of the 11th clock at the end of the successful transmission</li></ul>                                                                                                                                                                                                                                   |
|                      | <ul> <li>Transmission time-out is detected ((A)PS2STSn_T_TIMEOUT is set)</li> <li>When the PS2CRn_PS2_T/R bit is written '0'</li> </ul>                                                                                                                                                                                                                                                          |
|                      | • When the PS2CRn_PS2_EN bit is written '0'                                                                                                                                                                                                                                                                                                                                                      |
|                      | If a transmission is completed successfully, the PS/2 channel will automatically switch into receiving mode.                                                                                                                                                                                                                                                                                     |
|                      | The PS/2 channel interrupt request is generated on the low to high transition of (A)PS2STSn_XMIT_IDLE.                                                                                                                                                                                                                                                                                           |
| (A)PS2STSn_FE        | Framing Error flag (n = 0-2)<br>This flag (along with (A)PS2STn_R_TIMEOUT) is set following the falling edge of<br>the $11^{th}$ clock when PS/2 channel is receiving data, and the stop bit level sampled<br>on the falling edge of the $11^{th}$ clock does not match the stop bit polarity specified in<br>the control register.<br>This flag is cleared by reading the status register.      |
| (A)PS2STSn_PE        | Parity Error flag (n = 0-2)<br>This flag (along with (A)PS2STn_R_TIMEOUT) is set following the falling edge of<br>the $10^{th}$ clock when PS/2 channel is receiving data, and the parity bit level sampled<br>on the falling edge of the $10^{th}$ clock does not match either even or odd parity<br>specified in the control register.<br>This flag is cleared by reading the status register. |
| (A)PS2STSn_R_TIMEOUT | Receiving Time-out flag (n = 0-2)<br>This bit is set when PS2CRn_PS2_EN = 1, and one of following conditions is detected:                                                                                                                                                                                                                                                                        |
|                      | <ul> <li>The receiving bit time (time between clock falling edges) exceeds 300µs,<br/>if this time-out detection is enabled</li> </ul>                                                                                                                                                                                                                                                           |
|                      | • The time from the 1 <sup>st</sup> (start) clock falling edge to the 11 <sup>th</sup> (stop bit) clock falling edge exceeds 2 ms, if this time-out detection is enabled                                                                                                                                                                                                                         |
|                      | <ul> <li>Parity error (A)PS2STn_PE is detected</li> <li>Framing error (A)PS2STSn_FE is detected</li> </ul>                                                                                                                                                                                                                                                                                       |
|                      | The channel's PSCLKn pin is pulled down in hardware after the                                                                                                                                                                                                                                                                                                                                    |
|                      | (A)PS2STn_R_TIMEOUT bit is set and will be held low until the                                                                                                                                                                                                                                                                                                                                    |
|                      | (A)PS2STn_R_TIMEOUT bit is cleared by reading the status register in software.<br>The PS/2 channel interrupt request is generated on the low to high transition of<br>(A)PS2STn_R_TIMEOUT.                                                                                                                                                                                                       |
|                      |                                                                                                                                                                                                                                                                                                                                                                                                  |



(A)PS2STSn\_RDATA\_RDY Received Data Ready flag (n = 0-2)

If PS2CRn\_PS2\_EN = 1 and receive protocol is completed with no time-out, parity, or framing errors this bit is set following the falling edge of the 11<sup>th</sup> clock. It is also set when software attempts to abort current reception. This is done by clearing the PS2CRn\_PS2\_EN bit or setting the PS2CRn\_PS2\_T/R bit after the falling edge of the 10<sup>th</sup> clock. In any case, this bit indicates that the PS/2 receive register contains the data received from the PS/2 device. The channel's PSCLKn pin is pulled down in hardware after the (A)PS2STSn\_RDATA\_RDY bit is set and will be held low until the (A)PS2STSn\_RDATA\_RDY bit is cleared by reading the status register in software. The PS/2 channel interrupt request is generated on the low to high transition of (A)PS2STSn\_RDATA\_RDY.

#### 14.4.5 PS/2 Time-out and Status 2 Registers

The PS/2 Time-out control register is used to enable or disable PS/2 protocol time-out detection.

| Location                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                    | 7 | 6                                                                                                                                                                                                        | 5                                                                                                                                                                                                                                                                                                                                                                                       | 4 | 3       | 2            | 1                                                                     | 0        |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|--------------|-----------------------------------------------------------------------|----------|--|--|
| 7F44H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Read<br>Write                      | - | -                                                                                                                                                                                                        | -                                                                                                                                                                                                                                                                                                                                                                                       | - | TXTMSEL | TMR-<br>SPEN | TMOUTE<br>N1                                                          | TMOUTEN0 |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Reset                              | Х | Х                                                                                                                                                                                                        | Х                                                                                                                                                                                                                                                                                                                                                                                       | Х | 0       | 0            | 0                                                                     | 0        |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>Symbol</b><br>-<br>X<br>TXTMSEL |   | Not imp<br>Not def<br>Transm<br>1: Enat<br>control<br>0: Disa<br>control                                                                                                                                 | <ul> <li>Function</li> <li>Not implemented</li> <li>Not defined</li> <li>Transmit 2ms Time-out selection bit</li> <li>1: Enable in transmit mode, 2ms time-out is from the start bit falling edge to the line control bit clock rising edge</li> <li>0: Disable in transmit mode, 2ms time-out is from the start bit falling edge to the line control bit data falling edge.</li> </ul> |   |         |              |                                                                       |          |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | TMRSPEN                            |   | Enable 25ms Response Time-out detection bit<br>1: Enable response time-out detection after successful transmit completion<br>0: Disable response time-out detection after successful transmit completion |                                                                                                                                                                                                                                                                                                                                                                                         |   |         |              |                                                                       |          |  |  |
| TMOUTEN1Enable 2ms and 25ms Time-out detection and successful transmit completion1: Enable 2ms and 25ms Time-out detection for transmit/receive and 25ms time-out for<br>transmit only0: Disable 2ms time-out detection for transmit/receive and 25ms time-out for<br>transmit only0: Disable 2ms time-out detection for transmit/receive and 25ms time-out for<br>transmit only0: Disable 2ms time-out detection for transmit/receive and 25ms time-out for<br>transmit only0: Disable 2ms time-out is applied to the time interval from the state<br>falling edge to the line control bit data, or clock edges, depending on the vant<br>TXTMSEL. A 25ms time-out is applied to the time interval from the request<br>send state to the transmission start bit falling edge.In receive mode, 2ms time-out is applied to the time interval from the start bit<br>edge to the stop bit falling edge. |                                    |   |                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                         |   |         |              | e-out for<br>e-out for<br>the start bit<br>the value of<br>equest-to- |          |  |  |
| TMOUTEN0Enable 300us bit transfer Time-out detection bit1: Enable bit transfer 300µss time-out detection for transmit/receive0: Disable bit transfer 300µs time-out detection for transmit/receive.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                    |   |                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                         |   |         |              |                                                                       |          |  |  |



### 14.4.5.2 PS/2 Status 2 Register (PS2STATUS2)

The PS/2 Status 2 register is used to provide auxiliary status flags for all three PS/2 channels.

| Location |                        | 7     | 6                                                                                         | 5                                                                                                                           | 4                                                                                                            | 3                                                                                                               | 2                                                                                                    | 1                                                    | 0          |  |  |  |
|----------|------------------------|-------|-------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|------------------------------------------------------|------------|--|--|--|
| 7F48H    | Read                   | TxSB2 | TxSB1                                                                                     | TxSB0                                                                                                                       | RX_BUS<br>Y2                                                                                                 | RX_BUS<br>Y1                                                                                                    | RX_BUS<br>Y0                                                                                         | TxRsp                                                | -          |  |  |  |
|          | Write                  | -     | -                                                                                         | -                                                                                                                           | -                                                                                                            | -                                                                                                               | -                                                                                                    | -                                                    |            |  |  |  |
|          | Reset                  | 0     | 0                                                                                         | 0                                                                                                                           | 0                                                                                                            | 0                                                                                                               | 0                                                                                                    | 0                                                    | Х          |  |  |  |
|          | Symbol                 |       | Function                                                                                  | on                                                                                                                          |                                                                                                              |                                                                                                                 |                                                                                                      |                                                      |            |  |  |  |
|          | -                      |       | Not implemented                                                                           |                                                                                                                             |                                                                                                              |                                                                                                                 |                                                                                                      |                                                      |            |  |  |  |
|          | Х                      |       | Not def                                                                                   | Not defined                                                                                                                 |                                                                                                              |                                                                                                                 |                                                                                                      |                                                      |            |  |  |  |
|          | TxSB[2:0]<br>RX_BUSY[2 | 2:0]  | This bit<br>signal o<br>This bit<br>PS/2 cl<br>This bit<br>This bit<br>To avoi<br>respect | is set when<br>of a request-<br>is cleared b<br>nannel 2-0 F<br>is set when<br>is cleared b<br>d line conter<br>ive channel | to-send state<br>y reading the<br>Receiver Bus<br>the start bit<br>y reading the<br>ntion, the sof           | ssion start bi<br>e.<br>e respective<br>y flag<br>is received f<br>e respective<br>tware should<br>a from the P | t is not detect<br>status regist<br>rom the peri<br>status regist<br>d not start tra<br>S/2 device a | pheral device<br>ter.<br>ansmission v<br>nd the RX_E | 9.         |  |  |  |
|          | TxRsp                  |       | PS/2 R<br>This bit<br>of a suc<br>This bit<br><b>Note:</b> A<br>cleared<br>respect        | esponse Tir<br>is set when<br>ccessful tran<br>is cleared b<br>Il PS/2 chan<br>by reading t                                 | ne-out flag<br>no response<br>smission.<br>y reading an<br>nel interrupt s<br>he status reg<br>Neither inter | e start bit is only channel's sources and gister (PS2S)                                                         | detected with<br>status regist<br>the related s<br>TS0, PS2ST                                        | nin 25ms afte                                        | S2) of the |  |  |  |



### **15.0 FAN TACHOMETERS**

### 15.1 Fan Tachometer Features

- 8-bit resolution
- Two independent channels
- Clock prescaler
- Programmable preload value
- Threshold detector
- Support for both polling and interrupt driven operation
- Wake up from Idle and Power Down modes

The SST79LF008 has two independent pulse counters gated by external signals. The most common application for these counters is fan tachometer, where the external gate signal is a square wave signal from the fan, with its frequency proportional to the fan speed. By measuring the period of the square wave, a fan tachometer can monitor a

fan speed and also detect when a fan has seized. Fan tachometer input pins are FAN1 and FAN2. These pins are multiplexed with GPIO24 and GPIO25 respectively.

Tachometers use the 32.768 KHz oscillator clock as the time base source. The clock can be pre-scaled before being presented to a tachometer. On each rising edge of the FANn input, the preload value of the respective tachometer will be loaded into the 8 bit counter. The tachometer counter will then count up at each rising edge of the pre-scaled clock. A tachometer interrupt is generated if the counter reaches count COH (192 decimal).

### 15.2 Fan Tachometer Operation

Each fan tachometer includes a Clock Prescaler, a Pulse Counter, a Preload register, a Read Latch, and a Threshold Detector. See Figure 15-1.



FIGURE 15-1: Fan Tachometer Block Diagram

The clock prescaler provides the fan tachometer time base. The frequency of the prescaler output clock is equal to 32.768 KHz times the prescaler ratio (1/2 by default). The prescaler ratio for each channel can be independently specified via a prescaler register from 1/1 to 1/8, which accommodates fans with a wide range of speed.

The prescaler output pulses are counted by the pulse counter during the FANn input signal period. The counter is incremented on the rising edge of the prescaler clock, and it does not wrap around when the maximum FFH (255 decimal) count is reached. On the rising edge of the FANn signal, the pulse counter value is latched into the read latch and the preload value is loaded into the pulse counter. Thus, the read latch contains the measurement of the last input signal period in time base units.

The threshold value for the fan speed threshold detector is fixed at C0H (192 decimal) count. However, the initial value for the pulse counter is programmable via the preload reg-

ister. Hence, the pulse count can be scaled so that the threshold value corresponds to the desired lower limit of the fan speed. The preload value should be equal to 192 less the pulse count for the fan speed lower limit.

The counter is re-loaded with the preload value automatically on the FANn input signal rising edge, or when the software is writing to the preload register. Since software operations are asynchronous to the FANn signal, the tachometer reading may be incorrect until the second FANn rising edge after the write to the preload register.

When the pulse count equals or exceeds the threshold value, the respective FANn interrupt request is generated. The interrupt is cleared when preload register is written with the value below threshold.

The fan tachometers continue running in the Idle mode. Operation in the Power Down mode is controlled by software as shown Section 15.3.



### 15.3 Fan Tachometers MMCRs

### 15.3.1 Fan Tachometer 1 Read Register (FANCNT1)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | FANCNT1 |
| 7FBAH    |       | _7      | _6      | _5      | _4      | _3      | _2      | _1      | _0      |
|          | Write | -       | -       | -       | -       | -       | -       | -       | -       |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

#### Function

FANCNT1[7:0]

Not implemented Read-only register which returns the last latched Fan Tachometer 1 pulse count

### 15.3.2 Fan Tachometer 2 Read Register (FANCNT2)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | FANCNT2 |
| 7FBBH    |       | _7      | _6      | _5      | _4      | _3      | _2      | _1      | _0      |
|          | Write | -       | -       | -       | -       | -       | -       | -       | -       |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

### Function

FANCNT2[7:0]

Not implemented

Read-only register which returns the last latched Fan Tachometer 2 pulse count

### 15.3.3 Fan Tachometer 1 Preload Register (FAN1LD)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | FAN1LD |
| 7FBCH    | Write | _7     | _6     | _5     | _4     | _3     | _2     | _1     | _0     |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol

#### Function

FAN1LD[7:0]

Preload value for Fan Tachometer 1 pulse counter. Pulse counter is loaded with this value when the preload register is written to by 8051 firmware, and each time on the rising edge of FAN1 input.

### 15.3.4 Fan Tachometer 2 Preload Register (FAN2LD)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | FAN2LD |
| 7FBDH    | Write | _7     | _6     | _5     | _4     | _3     | _2     | _1     | _0     |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol FAN2LD[7:0]

#### Function

Preload value for Fan Tachometer 2 pulse counter. Pulse counter is loaded with this value when the preload register is written to by 8051 firmware, and each time on the rising edge of FAN2 input.



| Location |            | 7       | 6                                        | 5                                                                                                                                                                                                                                     | 4                                        | 3    | 2    | 1    | 0    |  |  |  |  |
|----------|------------|---------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|------|------|------|------|--|--|--|--|
|          | Read       | F2STOPE | F1STOPE                                  | -                                                                                                                                                                                                                                     | -                                        | F2S1 | F2S0 | F1S1 | F1S0 |  |  |  |  |
| 7FBEH    | Write      | N       | Ν                                        |                                                                                                                                                                                                                                       |                                          |      |      |      |      |  |  |  |  |
|          | Reset      | 0       | 0                                        | Х                                                                                                                                                                                                                                     | Х                                        | 0    | 1    | 0    | 1    |  |  |  |  |
|          | Symbol     |         |                                          | Function                                                                                                                                                                                                                              |                                          |      |      |      |      |  |  |  |  |
|          | -          |         | •                                        | Not implemented                                                                                                                                                                                                                       |                                          |      |      |      |      |  |  |  |  |
|          | Х          |         | Not def                                  | Not defined                                                                                                                                                                                                                           |                                          |      |      |      |      |  |  |  |  |
|          | F2STOPEN   | I       | 1: Tach<br>0: Tach                       | Fan Tachometer 2 operation in Power Down mode control bit<br>1: Tachometer 2 keeps running when 8051 enters into Power Down mode<br>0: Tachometer 2 is stopped and loaded with preload value when 8051 enters into<br>Power Down mode |                                          |      |      |      |      |  |  |  |  |
|          | F1STOPEN   | I       | 1: Tach<br>0: Tach                       | Fan Tachometer 1 operation in Power Down mode control bit<br>1: Tachometer 1 keeps running when 8051 enters into Power Down mode<br>0: Tachometer 1 is stopped and loaded with preload value when 8051 enters into<br>Power Down mode |                                          |      |      |      |      |  |  |  |  |
|          | F2S1, F2S0 | )       | 00: pre<br>01: pre<br>10: pre            | Fan Tachometer 2 Prescaler ratio<br>00: prescaler ratio = $1/1$<br>01: prescaler ratio = $1/2$<br>10: prescaler ratio = $1/4$<br>11: prescaler ratio = $1/8$                                                                          |                                          |      |      |      |      |  |  |  |  |
|          | F1S1, F1S0 | )       | Fan Tao<br>00: pre<br>01: pre<br>10: pre |                                                                                                                                                                                                                                       | Prescaler rat<br>= 1/1<br>= 1/2<br>= 1/4 | iio  |      |      |      |  |  |  |  |

### 15.3.5 Fan Tachometer Prescaler Register (FANTIMEBASE)



## 16.0 ANALOG TO DIGITAL CONVERTER (ADC)

### 16.1 ADC Features

- 10-bit resolution
- Eight input channels
- Two conversion modes
  - Single mode: one-time A/D conversion of one channel
  - Continuous mode: continuous cyclical conversion on one to four channels
- Sample-and-hold input circuit
- A/D interrupt requested at the end of conversion
- Standby mode with low power consumption
- Automatic entry into standby mode when 8051 is in Power Down mode

An ADC block diagram is shown in Figure 16-1. In addition to being the analog power supply voltage, AV<sub>DD</sub> is also used as the reference voltage for the A/D conversion. There are five 8-bit data registers that store up to four conversion results simultaneously. The eight analog input pins are divided into two groups: group 0 (ACH0 to ACH3), and group 1 (ACH4 to ACH7). Table 16-1specifies the relation between analog input channels and data registers.

#### TABLE 16-1: Analog Input Channels/Data Registers relationship

| GROUP0 | GROUP1 | ADC Data Register     |
|--------|--------|-----------------------|
| ACH0   | ACH4   | ADDRA[7:0]:ADDRL[1:0] |
| ACH1   | ACH5   | ADDRB[7:0]:ADDRL[3:2] |
| ACH2   | ACH6   | ADDRC[7:0]:ADDRL[5:4] |
| ACH3   | ACH7   | ADDRD[7:0]:ADDRL[7:6] |

T16-1.0 1320





### 16.2 ADC MMCRs

There are six 8-bit read only A/D data registers that are used to store the A/D conversion results.

#### 16.2.1 ADC Data register A (ADDRA)

| Location |       | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------|-------|-----|-----|-----|-----|-----|-----|-----|-----|
|          | Read  | AD9 | AD8 | AD7 | AD6 | AD5 | AD4 | AD3 | AD2 |
| 7F8EH    | Write | -   | -   | -   | -   | -   | -   | -   | -   |
|          | Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Symbol

#### Function

AD[9:2]

Not implemented

The most significant 8 bits of A/D conversion result for channel ACH0 or ACH4

### 16.2.2 ADC Data Register B (ADDRB)

| Location |       | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------|-------|-----|-----|-----|-----|-----|-----|-----|-----|
|          | Read  | BD9 | BD8 | BD7 | BD6 | BD5 | BD4 | BD3 | BD2 |
| 7F8FH    | Write | -   | -   | -   | -   | -   | -   | -   | -   |
|          | Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Symbol

### Function

BD[9:2]

### Not implemented

The most significant 8 bits of A/D conversion result for channel ACH1 or ACH5

### 16.2.3 ADC Data Register C (ADDRC)

| Location |       | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------|-------|-----|-----|-----|-----|-----|-----|-----|-----|
|          | Read  | CD9 | CD8 | CD7 | CD6 | CD5 | CD4 | CD3 | CD2 |
| 7F90H    | Write | -   | -   | -   | -   | -   | -   | -   | -   |
|          | Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Symbol

#### Function Not implemented

CD[9:2]

The most significant 8 bits of A/D conversion result for channel ACH2 or ACH6

### 16.2.4 ADC Data Register D (ADDRD)

| Location |       | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------|-------|-----|-----|-----|-----|-----|-----|-----|-----|
|          | Read  | DD9 | DD8 | DD7 | DD6 | DD5 | DD4 | DD3 | DD2 |
| 7F91H    | Write | -   | -   | -   | -   | -   | -   | -   | -   |
|          | Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Symbol

### Function

Not implemented

DD[9:2]

The most significant 8 bits of A/D conversion result for channel ACH3 or ACH7



### 16.2.5 ADC Data Register Lower Bits (ADDRL)

|                                                                                                                          | -                                                                                                                                                                            |     | •       | ,             |               |              |               |               |        |  |
|--------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------|---------------|---------------|--------------|---------------|---------------|--------|--|
| Location                                                                                                                 |                                                                                                                                                                              | 7   | 6       | 5             | 4             | 3            | 2             | 1             | 0      |  |
|                                                                                                                          | Read                                                                                                                                                                         | DD1 | DD0     | CD1           | CD0           | BD1          | BD0           | AD1           | AD0    |  |
| 7F92H                                                                                                                    | Write                                                                                                                                                                        | -   | -       | -             | -             | -            | -             | -             | -      |  |
|                                                                                                                          | Reset                                                                                                                                                                        | 0   | 0       | 0             | 0             | 0            | 0             | 0             | 0      |  |
| SymbolFunction-Not implementedDD[1:0]The least significant 2 bits of A/D conversion result for channel ACH3 or ACH7 (the |                                                                                                                                                                              |     |         |               |               |              |               |               |        |  |
|                                                                                                                          | CD[1:0]                                                                                                                                                                      |     | most si | gnificant 8 b | its of A/D co | nversion res | ult are store | d in register | ADDRD) |  |
|                                                                                                                          | most significant 8 bits of A/D conversion result are stored in register ADDRC)                                                                                               |     |         |               |               |              |               |               |        |  |
|                                                                                                                          | BD[1:0]The least significant 2 bits of A/D conversion result for channel ACH1 or ACH5 (the<br>most significant 8 bits of A/D conversion result are stored in register ADDRB) |     |         |               |               |              |               |               |        |  |
|                                                                                                                          | AD[1:0] The least significant 2 bits of A/D conversion result for channel ACH0 or ACH4 (the                                                                                  |     |         |               |               |              |               |               |        |  |

most significant 8 bits of A/D conversion result are stored in register ADDRA)

### 16.2.6 ADC Control and Status Register (ADCSR)

| Location |       | 7   | 6     | 5    | 4    | 3   | 2   | 1   | 0   |
|----------|-------|-----|-------|------|------|-----|-----|-----|-----|
|          | Read  | ADF | ADCEN | ADST | SCAN | CKS | CH2 | CH1 | CH0 |
| 7F93H    | Write |     |       |      |      |     |     |     |     |
|          | Reset | 0   | 0     | 0    | 0    | 0   | 0   | 0   | 0   |

| <b>Symbol</b><br>ADF | <b>Function</b><br>A/D conversion completion flag<br>Set by hardware in single mode when A/D conversion for the selected channel is<br>completed. Set by hardware in continuous mode when A/D conversion cycle for all<br>selected channels is completed. After ADF is set, the software must read ADCSR<br>register first, then write 0 to ADF in order to clear this bit. Writing 1 to ADF bit will be<br>ignored. |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADCEN                | Enable ADC bit<br>1: Enable ADC<br>0: Disable ADC, and switch ADC into standby mode<br>If this bit is set, ADC enters/exits standby mode automatically when 8051 enters/<br>exits Power Down mode.                                                                                                                                                                                                                   |
| ADST                 | <ul> <li>A/D conversion Start bit</li> <li>1: ADC conversion is started (in progress)</li> <li>0: ADC conversion is stopped</li> <li>This bit can be set or cleared by software in either single or continuous mode. It is cleared by hardware when conversion is completed in single mode only. The ADST bit is also automatically cleared when ADCEN bit is cleared.</li> </ul>                                    |
| SCAN                 | A/D conversion mode selection bit<br>1: Continuous mode<br>0: Single mode                                                                                                                                                                                                                                                                                                                                            |
| CKS                  | A/D clock selection bit (A/D conversion time = 5 periods of ADC clock)<br>1: The frequency of ADC clock is FCCLK/12, FCCLK – 8051 core clock frequency<br>0: The frequency of ADC clock is FCCLK /24, FCCLK – 8051 core clock frequency<br><b>Note:</b> ADC clock frequency must not exceed 2.0 MHz                                                                                                                  |
| CH[2:0]              | Analog input channels selection bits                                                                                                                                                                                                                                                                                                                                                                                 |



### 16.3 ADC Operations

ADC implements a successive approximation algorithm with 10-bit resolution. It has two operating modes: single mode and continuous mode. To prevent incorrect results of the A/D conversion, the conversion mode, clock, and channel selection bits must be changed only when conversion is

stopped (ADST = 0). It is acceptable to simultaneously write new values for the selection bits and to set the ADST bit in order to start a conversion.

| Group selection bit | Channel sele | ection bits | Selected I  | nput channels   |  |
|---------------------|--------------|-------------|-------------|-----------------|--|
| CH2                 | CH1          | CH0         | Single mode | Continuous mode |  |
| 0                   | 0            | 0           | ACH0        | ACH0            |  |
|                     |              | 1           | ACH1        | ACH0-ACH1       |  |
|                     | 1            | 0           | ACH2        | ACH0-ACH2       |  |
|                     |              | 1           | ACH3        | ACH0-ACH3       |  |
| 1                   | 0            | 0           | ACH4        | ACH4            |  |
|                     |              | 1           | ACH5        | ACH4-ACH5       |  |
|                     | 1            | 0           | ACH6        | ACH4-ACH6       |  |
|                     |              | 1           | ACH7        | ACH4-ACH7       |  |

TABLE 16-2: Channel and Mode Selection



Single mode is used only when a one-time A/D conversion on one channel is required. A typical, single mode conversion, with channel 1 (ACH1) selected, is described below. It is assumed that ADC is enabled (ADCEN = 1).

- The software enables the A/D interrupt (ADCINT-MSK = 1), selects a single mode (SCAN = 0) with ACH1 as the input channel (CH2 = CH1 = 0, CH0 = 1), and starts the A/D conversation (ADST = 1).
- When the A/D conversion is complete, the result is transferred by hardware into ADDRB and ADDRL[3:2] registers. Simultaneously, the ADF

flag is set to 1, the ADST bit is cleared to 0, and the ADC is stopped.

- 3. An ADC interrupt is generated since ADF = 1 and ADCINTMSK = 1.
- 4. In response to the ADC interrupt, the software interrupt service routine reads ADCSR, and then writes 0 in the ADF flag. After which, the software reads and processes, if necessary, the conversion result for the ACH1 channel.

Using the software, the ADST bit can be set to 1 to start the next A/D conversion, and steps 2 through 4 are repeated. See Figure 16-2 for a timing diagram of this example.



#### 16.3.2 Continuous Mode

Continuous mode is used to monitor analog inputs in a group of channels, with up to four channels per group. When the software sets the ADST bit to 1, the A/D conversion starts with the first channel in the group (ACH0 when CH2 = 0, ACH4 when CH2 = 1). If two or more channels are selected, the conversion of the second channel (ACH1 or ACH5) starts immediately after the conversion of the first channel is complete. The A/D conversion continues cyclically on all selected channels until the ADST bit is cleared to 0 by the software. The conversion results are stored in the ADC data registers. A typical continuous mode conversion, with three channels in group 0 (ACH0 to ACH2) selected, is described below. It is assumed that ADC is already enabled (ADCEN = 1).

- 1. The software enables the A/D interrupt (ADCINT-MSK = 1), selects continuous mode (SCAN = 1), and scans group 0 (CH2 = 0) with input channels ACH0 to ACH2 (CH1 = 1, CH0 = 0), and then starts the A/D conversion (ADST = 1).
- 2. After the A/D conversion of the first channel (ACH0) is complete, the conversion result is transferred by hardware to ADDRA and ADDRL[1:0] registers.
- 3. The conversion of the second channel (ACH1) is started automatically and the results are stored in ADDRC and ADDRL[3:2] registers.

- 4. The conversion cycle proceeds similarly for the third channel (ACH2) with results stored in ADDRC and ADDRL[5:4] registers. When the conversion of all selected channels (ACH0 through ACH2) is complete, the ADF flag is set to 1 and the conversion of the first channel (ACH0 starts again from step 2.
- 5. An ADC interrupt is generated because ADF = 1 and ADCINTMSK = 1.
- 6. In response to the ADC interrupt, the software reads ADCSR and writes 0 in the ADF flag. After which, the software reads and processes, if necessary, the conversion results for the three selected channels.
- 7. If the ADST bit remains set to 1, steps 2 through 6 are repeated automatically. When the ADST bit is cleared to zero in the software, the A/D conversion stops.

Using the software, the ADST bit can be set to 1 to restart the A/D conversion cycle from the first channel (ACH0), beginning with step 2. See Figure 16-3 for a timing diagram of this example.







FIGURE 16-3: Example of ADC Operation (Continuous Mode)



### 17.0 DIGITAL TO ANALOG CONVERTOR (DAC)

### 17.1 DAC Features

- 8-bit resolution
- Four D/A channels with one shared R-string (resistor ladder network) converter
- Sample-and-hold output circuits
- Independent enable/disable control for each channel
- 0V output for disabled channel
- Standby mode with low power consumption (all channels and shared R-string converter are disabled)
- Automatic entry into standby mode when 8051 is in Power Down mode

The DAC has one R-string digital-to-analog converter shared by 4 channels, see Figure 17-1. Each DAC channel generates an 8-bit resolution output and drives the corresponding output pin DAC0 to DAC3 via the sample-andhold circuit.

The output voltage is determined by the value written to the respective DAC data register when the DAC channel is enabled. The output voltage is 0V, regardless of the value in the respective DAC data register, when the DAC channel is disabled to reduce power consumption.

After reset and in power down mode, all four channels, as well as the shared R-string, are disabled and the voltages on the DAC0-3 outputs are 0V. AV<sub>DD</sub> analog power supply voltage is the reference voltage of the converter.



FIGURE 17-1: DAC Block Diagram



### 17.2 DAC MMCRs

### 17.2.1 DAC Data Channel Register 0 (DACDAT0)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | DACDAT0 |
| 7F4CH    | Write | _7      | _6      | _5      | _4      | _3      | _2      | _1      | _0      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol DACDAT0[7:0] Function

DAC channel 0 input data

### 17.2.2 DAC Data Channel Register 1 (DACDAT1)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | DACDAT1 |
| 7F4DH    | Write | _7      | _6      | _5      | _4      | _3      | _2      | _1      | _0      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol DACDAT1[7:0]

### Function

DAC channel 1 input data

### 17.2.3 DAC Data Channel Register 2 (DACDAT2)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | DACDAT2 |
| 7F4EH    | Write | _7      | _6      | _5      | _4      | _3      | _2      | _1      | _0      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

#### Symbol DACDAT2[7:0]

### Function

DAC channel 2 input data

### 17.2.4 DAC Data Channel Register 3 (DACDAT3)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0        |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|----------|
|          | Read  | DACDAT3 | DACDAT3_ |
| 7F4FH    | Write | _7      | _6      | _5      | _4      | _3      | _2      | _1      | 0        |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0        |

Symbol DACDAT3[7:0]

### Function

DAC channel 3 input data



| Location |                           | 7 | 6                                                                       | 5                                                                                                                                                                                                                                                                                                                                                                                                      | 4     | 3      | 2      | 1      | 0      |  |  |  |
|----------|---------------------------|---|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|--------|--------|--------|--|--|--|
|          | Read                      | - | -                                                                       | -                                                                                                                                                                                                                                                                                                                                                                                                      | DACEN | DACEN3 | DACEN2 | DACEN1 | DACEN0 |  |  |  |
| 7F50H    | Write                     |   |                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                        |       |        |        |        |        |  |  |  |
|          | Reset                     | 0 | 0                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                      | 0     | 0      | 0      | 0      | 0      |  |  |  |
|          | Symbol<br>DACEN<br>DACEN3 |   | DAC R<br>1: Enat<br>0: Disa<br>If this b<br>enters/<br>DAC C<br>1: Enat | Function         DAC R-string Enable bit         1: Enable DAC R-string         0: Disable DAC R-string (standby mode DAC0-DAC3 output voltage is 0V)         If this bit is set, DAC also enters/exits standby mode automatically when 8051         enters/exits Power Down mode.         DAC Channel 3 Enable bit         1: Enable – DAC3 output voltage level is specified by the value in DACDAT3 |       |        |        |        |        |  |  |  |
|          | DACEN2                    |   | 0: Disa<br>DAC C<br>1: Enat<br>register                                 | register<br>0: Disable – DAC3 output voltage is 0V<br>DAC Channel 2 Enable bit<br>1: Enable – DAC2 output voltage level is specified by the value in DACDAT2<br>register                                                                                                                                                                                                                               |       |        |        |        |        |  |  |  |
|          | DACEN1                    |   | DAC C<br>1: Enat<br>register<br>0: Disa                                 | 0: Disable – DAC2 output voltage is 0V<br>DAC Channel 1 Enable bit<br>1: Enable – DAC1 output voltage level is specified by the value in DACDAT1<br>register<br>0: Disable – DAC1 output voltage is 0V                                                                                                                                                                                                 |       |        |        |        |        |  |  |  |
|          | DACEN0                    |   | 1: Enat<br>register                                                     | <ul> <li>DAC 1 output voltage is 0V</li> <li>DAC Channel 0 Enable bit</li> <li>1: Enable – DAC0 output voltage level is specified by the value in DACDAT0 register</li> <li>0: Disable – DAC0 output voltage is 0V.</li> </ul>                                                                                                                                                                         |       |        |        |        |        |  |  |  |

#### 17.2.5 DAC Control Register (DACCTRL)

### 17.3 DAC Operations

### 17.3.1 Output Voltage

For each channel, the DAC converts the input digital value stored in the respective DAC data register into an analog output voltage, relative to the analog ground pin (AV<sub>SS</sub>). The analog power supply voltage AV<sub>DD</sub> is used as the reference voltage of the converter. The output voltage level on DACn pin for enabled channel n = 0-3 can be found as follows:  $V_{OUT} = (DACDATn[7:0]) * (AV_{DD} / 256)$ 

### 17.3.2 Conversion Cycle

Since there is only one R-string, an interleaving scheme is used to periodically convert each of the DAC data registers and refresh the DAC output Sample-and-hold circuits. When a DAC channel is selected for conversion, the content of the respective data register is copied into an 8-bit intermediate register, which holds the value throughout the entire conversion time slot allocated for this channel. At the end of the conversion time the corresponding DAC Sample-and-hold circuit is updated. Each channel is allocated 24 core clocks for D/A conversion. A disabled channel will not be converted, but it will still occupy its time slot. Hence, the total conversion cycle for all 4 channels always occupies 96 core clock periods, i.e., conversion cycle time is equal to (96 \*  $T_{CCLK}$ .).

### 17.3.3 DAC Channel Control

After SST79LF008 chip reset, the R-string and all DAC channels are disabled (DACCTRL register is cleared to 00H). In this state, no D/A conversion is performed, and the DAC is in standby mode with minimum current consumption.

The shared DAC R-string is enabled via the DACEN bit in the DACCTRL register. Each DAC channel can be enabled by setting the corresponding DACENn (n = 0 to 3) bit in the DACCTRL register. Once the DAC channel is enabled, D/A converter outputs the voltage level, which is specified by the respective data register DACDATn.



Each DAC channel can be independently disabled by clearing the DACENn bit in the DACCTRL register. If the DAC channel is disabled, its output voltage is 0V regardless of the value stored in the channel's data register.

#### 17.3.4 Standby Mode

The DAC standby mode, with all DAC channels and the shared R-string disabled, provides the minimum possible DAC power consumption. All DAC0-DAC3 output voltages are forced to 0V in the standby mode.

The DAC switches to the standby mode automatically, when 8051 is in Power Down mode. This happens regardless of the state of the DACENn bits in the DACCTRL register.



### 18.0 KEYBOARD CONTROLLER HOST INTERFACE

### **18.1 Keyboard Controller Interface Overview**

The SST79LF008 provides a 8042-style keyboard controller (KBC) host interface which is accessible via an LPC bus at standard I/O addresses 60H and 64H. This guarantees compatibility with the PC system BIOS and OS keyboard/ mouse services, as well as with any legacy applications that access keyboard ports directly.

The KBC interface includes the following 8-bit registers: KBC data write register, KBC data read register, KBC com-

mand write register, and KBC status register. The host processor accesses KBC interface registers at two addresses in the LPC I/O space. The 8051 core accesses the KBC interface registers at three addresses in external data memory space. Table 18-1 describes the register mapping to the host I/O space and 8051 memory space, as well as the access type for each register.

|                      | Address and<br>s Type | Function                  | 8051 Memory | mapped Address and Access<br>Type     |
|----------------------|-----------------------|---------------------------|-------------|---------------------------------------|
| Address <sup>1</sup> | Access                |                           | Access      | Address (MMCR register)               |
|                      | Write                 | Host-to-KBC data write    | Read        | 7FF1H (KBCDATA)                       |
| 60H                  | Read                  | Host-from-KBC data read   | Write       | 7FF1H (KBCDATA) or<br>7FFAH (AUXDATA) |
|                      | Write                 | Host-to-KBC command write | Read        | 7FF1H (KBCDATA)                       |
| 64H                  | Read                  | Host-from-KBC status read | Write/Read  | 7FF2H (KBCSTS)                        |

#### TABLE 18-1: Keyboard Controller Interface Mapping

T18-1.1320

1. The default base address for KBC host interface ports can be changed via SST79LF008 configuration registers (see Section 23). For simplicity the description in Section 18.1 refers to default addresses.

When the Host writes a command byte to the KBC through port 64H, this sets the C/D bit in the KBC status register and the IBF bit in the KBC status register. When the Host writes a data byte to the KBC through port 60H, this clears the C/D bit in the KBC status register and sets the IBF bit in the KBC status register. When the Host reads data from the KBC through port 60H, the OBF bit in the KBC status register is cleared. See detailed bit description for the KBC status register in the next section.

The KBC interface also includes a mechanism for the generation of IRQ1 and IRQ12 interrupts to the LPC Host when data from the keyboard or mouse is ready to be read by the system.

### 18.2 Keyboard Controller Interface MMCRs

| 18.2.1 Keyboard Data Register ( | (KBCDATA) |
|---------------------------------|-----------|
|---------------------------------|-----------|

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | KBCDATA |
| 7FF1H    | Write | _7      | _6      | _5      | _4      | _3      | _2      | _1      | _0      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

### Symbol KBCDATA[7:0]

#### Function

When the 8051 core reads from this register, the data returned is the last data byte written by the LPC Host to port 60H (if C/D bit is 0), or the last command byte written by the LPC Host to port 64H (if C/D bit is 1). The IBF bit in the status register is also cleared when the 8051 core reads this register. The 8051 core writes to this register the data byte from the KBC or keyboard, which will be returned to the LPC Host on the next read from port 60H. The OBF bit in the status register is set, and the internal KOBF signal is asserted when the 8051 core writes to this register. See Table 18-2.



### 18.2.2 Keyboard Status Register (KBCSTS)

| Location |                                              | 7  | 6                                                                                                                                                                                                                               | 5                                                                                                                                                                                                                                                                                                                                            | 4                                                                                                                                                                                                                                                                              | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2                                                                                                                                                                  | 1                                                                                                   | 0                                    |
|----------|----------------------------------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--------------------------------------|
|          | Read                                         | UD | UD                                                                                                                                                                                                                              | AUXOBF/                                                                                                                                                                                                                                                                                                                                      | UD                                                                                                                                                                                                                                                                             | C/D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | UD                                                                                                                                                                 | IBF                                                                                                 | OBF                                  |
| 7FF2H    | Write                                        |    |                                                                                                                                                                                                                                 | UD                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                    | -                                                                                                   | -                                    |
|          | Reset                                        | 0  | 0                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                            | 0                                                                                                                                                                                                                                                                              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                  | 0                                                                                                   | 0                                    |
|          | Symbol<br>-<br>UD<br>AUXOBF/UI<br>IBF<br>OBF |    | Functi<br>Not imp<br>User de<br>Auxiliar<br>If AUXS<br>follows<br>Set to '<br>Cleared<br>C/D CC<br>Set to '<br>Cleared<br>Input B<br>Set wh<br>Cleared<br>Input B<br>Set wh<br>Cleared<br>Interrup<br>Output<br>Set wh<br>AUXDA | on<br>olemented<br>efined bits. C<br>ry Output Bu<br>SEL=1 in KB<br>:<br>1' when 805<br>d to '0' when<br>ommand/Dat<br>1' when the<br>d to '0' when<br>d to '0' when<br>d to '0' when<br>d to '0' when<br>fuffer Full fla<br>of the LPC<br>d when the L<br>bot request K0<br>Buffer Full fl<br>en the 8051<br>ATA register a<br>d when the L | Can be writte<br>ffer Full flag<br>DCFG regis<br>1 writes into<br>8051 writes<br>a flag (read<br>LPC Host w<br>the LPC Host<br>g (read only)<br>Host writes of<br>3051 core rea<br>CIBF to 805 <sup>-1</sup><br>ag (read only<br>core writes i<br>at address 7<br>.PC Host rea | n/read by the<br>(if AUXSEL=<br>ter this read<br>the AUXDA<br>into the KBC<br>only)<br>rites comma<br>ost writes dat<br>data or comma<br>data | e 8051 core.<br>=1) or User of<br>only bit is co<br>TA register a<br>CDATA regis<br>nd byte to po<br>ta byte to po<br>nand to port<br>TA register a<br>when this b | defined bit (if<br>ontrolled by h<br>st 7FFAH<br>ster at 7FF1H<br>ort 64H<br>rt 60H<br>t address 7F | AUXSEL=0)<br>hardware as<br>H<br>F1H |

### 18.2.3 Keyboard Auxiliary Data Register (AUXDATA)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | AUXDATA |
| 7FFAH    | Write | _7      | _6      | _5      | _4      | _3      | _2      | _1      | _0      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol AUXDATA[7:0]

### Function

When the 8051 core reads from this register the data returned is the last 8051 written data.

The 8051 core writes to this register the data byte from Mouse/Auxiliary Device which will be returned to the LPC Host on the next read from port 60H. The OBF bit in the status register is set, and the internal MOBF signal is asserted, when the 8051 core writes to this register. See Table 18-2.



-

#### Advance Information

| Location |          | 7      | 6                                                                           | 5                                                                                                                                                               | 4             | 3              | 2            | 1             | 0             |  |  |  |
|----------|----------|--------|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------------|--------------|---------------|---------------|--|--|--|
|          | Read     | AUXSEL | -                                                                           | OBFEN                                                                                                                                                           | AUX-          | -              | PCOBFE       | SAEN          | -             |  |  |  |
| 7FF4H    | Write    |        |                                                                             |                                                                                                                                                                 | OBFEN         |                | N            |               |               |  |  |  |
|          | Reset    | 0      | Х                                                                           | 0                                                                                                                                                               | 0             | Х              | 0            | 0             | Х             |  |  |  |
|          | Symbol   |        | Functi                                                                      | Function                                                                                                                                                        |               |                |              |               |               |  |  |  |
|          | -        |        |                                                                             | blemented                                                                                                                                                       |               |                |              |               |               |  |  |  |
|          | Х        |        | Not de                                                                      |                                                                                                                                                                 |               |                |              |               |               |  |  |  |
|          | AUXSEL   |        |                                                                             |                                                                                                                                                                 | ontrol of Aux |                |              |               |               |  |  |  |
|          |          |        |                                                                             |                                                                                                                                                                 | ne status reg | ister is contr | olled by har | dware write a | at address    |  |  |  |
|          |          |        |                                                                             | or 7FF1H                                                                                                                                                        | o ctatuc roa  | vr dofinod bit | (LID) contro | llod by 9051  |               |  |  |  |
|          |          |        |                                                                             | <ol> <li>AUXOBF bit in the status register is a user defined bit (UD) control<br/>software.</li> </ol>                                                          |               |                |              |               |               |  |  |  |
|          | OBFEN    |        |                                                                             | KIRQ control bit                                                                                                                                                |               |                |              |               |               |  |  |  |
|          |          |        | 1: KIRQ follows PCOBF state                                                 |                                                                                                                                                                 |               |                |              |               |               |  |  |  |
|          |          |        |                                                                             | : KIRQ is forced low (de-asserted)                                                                                                                              |               |                |              |               |               |  |  |  |
|          |          |        |                                                                             | PCOBF is an internal signal, which reflects the status of 8051 and writes at                                                                                    |               |                |              |               |               |  |  |  |
|          |          |        |                                                                             | address 7FF1H or at address 7FFDH. KIRQ is an internal source of IRQ1 interrupt for Serial IRQ transmission. See Figure 18-1 for KBC Interrupt Control diagram. |               |                |              |               |               |  |  |  |
|          | AUXOBFEN | J      |                                                                             | control bit                                                                                                                                                     |               | s i iguio io   |              |               | or diagram.   |  |  |  |
|          |          | -      |                                                                             | Q follows M                                                                                                                                                     | OBF state     |                |              |               |               |  |  |  |
|          |          |        |                                                                             |                                                                                                                                                                 | ow (de-assei  | ,              |              |               |               |  |  |  |
|          |          |        |                                                                             |                                                                                                                                                                 |               |                |              |               | es at address |  |  |  |
|          |          |        |                                                                             |                                                                                                                                                                 | r KBC Interru |                |              | or Serial IRQ | transmission. |  |  |  |
|          | PCOBFEN  |        |                                                                             | PCOBF sou                                                                                                                                                       |               |                | lagian.      |               |               |  |  |  |
|          |          |        | 1: PCOBF signal reflects the value of bit 0 in the PCOBF register at addres |                                                                                                                                                                 |               |                |              |               |               |  |  |  |
|          |          |        | 7DDFF                                                                       | 7DDFH (PCOBF = PCOBFL)                                                                                                                                          |               |                |              |               |               |  |  |  |
|          |          |        |                                                                             |                                                                                                                                                                 |               | 8051 and w     | rites to KBC | DATA registe  | er at address |  |  |  |
|          |          |        |                                                                             | (PCOBF =                                                                                                                                                        | ,             | -:+            |              |               |               |  |  |  |
|          | SAEN     |        |                                                                             | GA20 Software control Enable bit                                                                                                                                |               |                |              |               |               |  |  |  |
|          |          |        |                                                                             | 1: Enable software control of GA20 pin<br>0: Enable hardware control of GA20 pin                                                                                |               |                |              |               |               |  |  |  |
|          |          |        |                                                                             |                                                                                                                                                                 |               | - 1            |              |               |               |  |  |  |

### 18.2.4 Keyboard Controller Configuration Register (KBDCFG)

### 18.2.5 PCOBF Register (PCOBF)

| Location |       | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|----------|-------|---|---|---|---|---|---|---|--------|
|          | Read  | - | - | - | - | - | - | - | PCOBFL |
| 7FFDH    | Write |   |   |   |   |   |   |   |        |
|          | Reset | Х | Х | Х | Х | Х | Х | Х | 0      |

### Symbol

### Function

Х PCOBFL Not implemented

- Not defined
- - PCOBF firmware controlled latch

PCOBF signal reflects the value of this bit provided PCOBFEN=1. See Figure 18-1



### 18.2.6 IRQ1 and IRQ12 Control

After SST79LF008 chip reset, all the KBC status flags and the internal control signals PCOBF, KOBF, and MOBF are reset to 0. Respectively, KIRQ and MIRQ requests are de-

asserted low, which results in both IRQ1 and IRQ12 being reported to the LPC Host as "low" via Serialized IRQ bus.

At run time the status flags and the internal control signals are changed in hardware according to Table 18-2.

IRQ12 interrupts are reported to the LPC Host as "high" via

#### TABLE 18-2: KBC Output Buffer Flags Control

| Operation                                        | MOBF@7FFA | KOBF@7FF1 | OBF<br>(KBCSTS[0]) | AUXOBF <sup>1</sup><br>(KBCSTS[5]) |
|--------------------------------------------------|-----------|-----------|--------------------|------------------------------------|
| 8051 Writes to KBCDATA register at address 7FF1H | No Change | 1         | 1                  | 0                                  |
| 8051 Writes to AUXDATA register at address 7FFAH | 1         | No Change | 1                  | 1                                  |
| LPC Host reads Port 60H                          | 0         | 0         | 0                  | No Change                          |

1. This flag is controlled by hardware only if AUXSEL = 1

KIRQ and MIRQ interrupt requests reflect changing in the status flags according to Tables 18-3 and 18-4 and Figure 18-1. Whenever KIRQ/MIRQ is asserted, IRQ1/

#### TABLE 18-3: KBC Interrupt Control

| OBFEN<br>(KBDCFG[5]) | PCOBFEN<br>(KBDCFG[2]) | KIRQ                            |
|----------------------|------------------------|---------------------------------|
| 0                    | X <sup>1</sup>         | KIRQ is inactive and driven low |
| 1                    | 0                      | KIRQ = KOBF                     |
| 1                    | 1                      | KIRQ = PCOBFL                   |

Serialized IRQ bus

1. X = Not defined

#### TABLE 18-4: Mouse Interrupt Control

| AUXOBFEN<br>(KBDCFG[4]) | MIRQ                            |
|-------------------------|---------------------------------|
| 0                       | MIRQ is inactive and driven low |
| 1                       | MIRQ = MOBF                     |

T18-4.0 1245

T18-3.0 1245

T18-2.1245



FIGURE 18-1: KBC Interrupt Control



### 18.3 Keyboard Matrix Scan Control

The SST79LF008 provides 16 scan outputs KSO[15:0] and 8 scan inputs KSI[7:0] for standard notebook keyboard matrix scanning. These lines can be accessed by 8051 firmware via the KEYSCAN register described below.

### 18.3.1 Keyboard Scan-In / Scan-Out Register (KEYSCAN)

| Location |       | 7    | 6      | 5    | 4      | 3     | 2     | 1     | 0     |
|----------|-------|------|--------|------|--------|-------|-------|-------|-------|
|          | Read  | KSI7 | KSI6   | KSI5 | KSI4   | KSI3  | KSI2  | KSI1  | KSI0  |
| 7F04H    | Write | -    | KSOINV | KSEN | KSOLOW | KSOC3 | KSOC2 | KSOC1 | KSOC0 |
|          | Reset | 0    | 0      | 1    | 0      | 0     | 0     | 0     | 0     |

| Symbol              | Function                                                                                                                                                                               |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -                   | Not implemented                                                                                                                                                                        |
| KSI[7:0]            | When the KEYSCAN register is read, it returns the state of KSI[7:0] pins via these read-only bits. Any KSI pin transitions from high to low will assert KEY interrupt request to 8051. |
| KSOINV              | Scanner output polarity control bit (write-only)                                                                                                                                       |
| KSEN                | Scanner enable mask (write-only)                                                                                                                                                       |
| KSOLOW<br>KSOC[3:0] | Scanner low output control bit (write-only)<br>Scanner output selection bits (write-only)                                                                                              |

### TABLE 18-5: KSO[15:0] Control

| KSEN | KSOLOW         | KSOINV | KSOC[3:0] | KSO[15:0]                                                   |
|------|----------------|--------|-----------|-------------------------------------------------------------|
| 1    | X <sup>1</sup> | Х      | Х         | All lines are high                                          |
| 0    | 1              | 1      | Х         | All lines are high                                          |
| 0    | 1              | 0      | Х         | All lines are low                                           |
| 0    | 0              | 1      | n         | KSO[n] line is high and all other lines are low             |
| 0    | 0              | 0      | n         | KSO[n] line is low, and all other lines are high (n = 15-0) |

1. X = Not defined

T18-5.0 1245



### 19.0 GA20 AND CPU RESET HARDWARE CONTROL

The keyboard controller GA20 output is a PC legacy feature, which provides capability to mask the address line A20 in order to emulate 8086 20-bit address space. Similarly the KBC to CPU reset output, KBRST#, is a legacy host CPU reset signal which can be triggered via the KBC. The SST79LF008 device contains on-chip logic to provide the host processor with direct control of GA20 and KBRST# outputs. This control is implemented via specific command/data sequences sent over LPC interface to ports 64H and 60H. Optionally, this on-chip logic can be disabled via SAEN bit in the KBDCFG register and SKBEN bit in the GA20 register, requesting control of the GA20 and/or KBRST# outputs to the 8051 firmware.

# 19.1 GA20 State Machine

Table 19-1 lists typical GA20 command sequences sent by the LPC Host to control the GA20 output from KBC. The hardware GA20 state machine, which interprets these sequences when GA20 hardware is enabled, is shown in Figure 19-1. After SST79LF008 chip reset, the state machine is in S0 state. Note that during a valid GA20 command sequence the IBF flag in the KBC status register is not '1'. This makes the hardware GA20 control (when SAEN = 0) transparent to 8051 firmware.

| I/O Port | R/W | VALUE           | IBF | GA20           | Functions           |
|----------|-----|-----------------|-----|----------------|---------------------|
| 64H      | W   | D1              | 0   | Q <sup>1</sup> | Set GA20 command    |
| 60H      | W   | DF              | 0   | 1              |                     |
| 64H      | W   | D1              | 0   | Q              | Clear GA20 command  |
| 60H      | W   | DD              | 0   | 0              |                     |
| 64H      | W   | D1              | 0   | Q <sup>1</sup> | Extended Set GA20   |
| 60H      | W   | DF              | 0   | 1              | command             |
| 64H      | W   | FF              | 0   | 1              |                     |
| 64H      | W   | D1              | 0   | Q              | Extended Clear GA20 |
| 60H      | W   | DD              | 0   | 0              | command             |
| 64H      | W   | FF              | 0   | 0              |                     |
| 64H      | W   | D1              | 0   | Q              | Invalid Sequence    |
| 64H      | W   | XX <sup>2</sup> | 1   | Q              |                     |
| 64H      | W   | FF              | 1   | 0              |                     |

#### TABLE 19-1: GA20 Command Sequences

1. Q means no changes

2. XX means any command code except D1

T19-1.1320





FIGURE 19-1: GA20 State Machine

### 19.2 GA20 and KBRST# MMCRs

### 19.2.1 GA20 Output Register (GA20)

| Location |       | 7 | 6 | 5 | 4 | 3     | 2     | 1 | 0       |
|----------|-------|---|---|---|---|-------|-------|---|---------|
|          | Read  | - | - | - | - | SKBEN | KBRST | - | GA20    |
| 7FFBH    | Write |   |   |   |   |       |       |   | GA20_SW |
|          | Reset | Х | Х | Х | Х | 0     | 0     | Х | 1       |

| Symbol  | Function                                                                                                                                                              |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -       | Not implemented                                                                                                                                                       |
| Х       | Not defined                                                                                                                                                           |
| SKBEN   | KBRST# Software control Enable bit                                                                                                                                    |
|         | 1: Enable KBRST# software control                                                                                                                                     |
|         | 0: Enable KBRST# hardware control                                                                                                                                     |
| KBRST   | KBRST# Pulse generation control bit                                                                                                                                   |
|         | Set/cleared by software. When SKBEN = 1, the '0' to '1' transition of this bit generates a pulse on KBRST# output (low going pulse with duration more than $6\mu$ s). |
| GA20    | GA20 software control bit/Status flag                                                                                                                                 |
|         | Reading this bit returns the present state of the GA20 output signal                                                                                                  |
| GA20_SW | Writing to this bit set/reset software controlled GA20_SW signal (which is output to GA20 pin provided SAEN = 1)                                                      |



When SKBEN = 0, KBRST# hardware control is enabled, a KBRST# low going pulse is generated automatically in response to the LPC Host command FEH written to port 64H (pulse duration is 200 cycles of LPC clock LCLK). In this case the FEH command does not set the IBF flag in the KBC status register. When SKBEN = 1, 8051 firmware controls KBRST# pin, and it can generate KBRST# low going pulse by writing '0', and then '1' to the KBRST bit (pulse duration is 200 cycles of 8051 core clock CCLK).

When SAEN'='0, GA20 hardware control is enabled, the GA20 output is controlled by the LPC Host command/data sequences written to ports 64H/60H as shown on Figure 19-1 and in Table 19-1. Additionally, in this mode, the 8051 core can set/reset GA20 line via SETGA20 and RSTGA20 registers described below. Since the LPC Host GA20 sequence and 8051 writes to SETGA20/RSTGA20 registers, they asynchronously control the same GA20 output. It is necessary for 8051 to read back the GA20 status via GA20 register to confirm the actual GA20 state.

### 19.2.2 Set GA20 Register (SETGA20)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2     | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|-------|--------|--------|
|          | Read  | SGA207 | SGA206 | SGA205 | SGA204 | SGA203 | SGA20 | SGA201 | SGA200 |
| 7FFEH    | Write |        |        |        |        |        |       |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0     | 0      | 0      |

Sga20[7:0]

#### Function

Any writes to this register sets hardware controlled GA20 asynchronously. Read from this register always returns 00H.

#### 19.2.3 Reset GA20 Register (RSTGA20)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2     | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|-------|--------|--------|
|          | Read  | RGA207 | RGA206 | RGA205 | RGA204 | RGA203 | RGA20 | RGA201 | RGA200 |
| 7FFFH    | Write |        |        |        |        |        |       |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0     | 0      | 0      |

Symbol RGA20[7:0]

#### Function

Any writes to this register resets hardware controlled GA20 asynchronously. Read from this register always returns 00H.

When SAEN = 1, only the 8051 core controls GA20 pin via direct writes to bit 0 of GA20 register. The LPC Host command detection is disabled when SAEN = 1, but writing to SETGA20 and RSTGA20 registers still affects the hardware controlled GA20\_HW signal, even though it is not output to GA20 pin. Note that hardware and software controlled GA20 signals are independent. Figure 19-2 shows how the LPC Host and KBC firmware controls the GA20 output.

After SST79LF008 chip reset, the KBRST# signal is '1', hardware controlled GA20\_HW signal is '1', and software controlled GA20 SW signal is '0'. Reset value of

SAEN = 0, thus, GA20 status is returned by default as  $GA20_HW = 1$ . Note that both GA20 and KBRST# signals are multiplexed with GPIO pins, and should be properly selected by 8051 firmware in order to utilize the respective functions.







### 20.0 ACPI EMBEDDED CONTROLLER INTERFACE

### 20.1 ACPI Embedded Controller Interface Overview

ACPI specification defines a hardware and software interface between the operating system and an embedded controller (EC). This interface can be used by the standard operating system driver to directly communicate with the embedded controller. SST79LF008 provides two2 ACPI compliant EC interfaces ECI0 and ECI1. EC interface includes the following 8-bit registers: EC data write register, EC data read register, EC command write register, and EC status register. The host processor accesses EC interface registers at two addresses in the LPC I/O space. The 8051 core accesses EC interface registers at two addresses in the external data memory space. Figure 20-1 describes the register mapping to the host I/O space and 8051 memory space as well as access type for each register.

| LPC Host I/O A<br>Access |        | Function                 | 8051 Memory mapped Address and Access Type |                           |  |  |
|--------------------------|--------|--------------------------|--------------------------------------------|---------------------------|--|--|
| Address <sup>1</sup>     | Access |                          | Access                                     | Address (MMCR register)   |  |  |
| 62H for ECI0             | Write  | Host-to-EC data write    | Read                                       | 7F53H (ECIDATA) for ECI0  |  |  |
| 68H for ECI1             | Read   | Host-from-EC data read   | Write                                      | 7F80H (ECIDATA1) for ECI1 |  |  |
| 66H for ECI0             | Write  | Host-to-EC command write | Read                                       | 7F53H (ECIDATA) for ECI0  |  |  |
|                          |        |                          |                                            | 7F80H (ECIDATA1) for ECI1 |  |  |
| 6CH for ECI1             | Read   | Host-from-EC status read | Write/Read                                 | 7F54H (ECISTS) for ECI0   |  |  |
|                          |        |                          |                                            | 7F81H (ECISTS1) for ECI1  |  |  |

### TABLE 20-1: Embedded Controller Interface Mapping

The default base address for EC host interface ports can be changed via SST79LF008 configuration registers (see Section 23.0).
 For simplicity the description in Section 20.1 refers to default addresses.

When the Host writes command byte to EC through port 66H (6CH), the ECISTSn\_C/D bit is set and the ECISTSn\_IBF bit is set in the respective EC status register. When the Host writes data byte to EC through port 62H (68H), the ECISTSn\_C/D bit is cleared and the ECISTSn\_IBF bit is set in the respective EC status register. When the Host reads data from EC through port 62H (68H), the ECISTSn\_OBF bit in the respective EC status register is cleared. See detailed bit description for EC status registers in Section 20.2.



### 20.2 Embedded Controller Interface MMCRs

### 20.2.1 ECI Data Register (ECIDATA)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | ECIDATA |
| 7F53H    | Write | _7      | _6      | _5      | _4      | _3      | _2      | _1      | _0      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol ECIDATA[7:0]

#### Function

When 8051 core reads from this register, data returned is the last data byte written by the LPC Host to port 62H (if ECISTSn\_C/D bit in ECISTS register is 0), or the last command byte written by the LPC Host to port 66H (if ECISTSn\_C/D bit is 1). The ECISTSn\_IBF bit in ECISTS register is also cleared when 8051 core reads this register.

When 8051 core writes to this register, it provides data to be returned to the LPC Host on the next read from port 62H. The ECISTSn\_OBF bit in ECISTS register is also set when 8051 core writes to this register.

#### 20.2.2 ECI Data Register 1 (ECIDATA1)

| Location |       | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0         |
|----------|-------|----------|----------|----------|----------|----------|----------|----------|-----------|
|          | Read  | ECIDATA1 | ECIDATA1_ |
| 7F80H    | Write | _7       | _6       | _5       | _4       | _3       | _2       | _1       | 0         |
|          | Reset | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0         |

Symbol ECIDATA1[7:0]

#### Function

When 8051 core reads from this register, data returned is the last data byte written by the LPC Host to port 68H (if ECISTSn\_C/D bit in ECISTS1 register is 0), or the last command byte written by the LPC Host to port 6CH (if ECISTSn\_C/D bit is 1). The ECISTSn\_IBF bit in ECISTS1 register is also cleared when 8051 core reads this register.

When 8051 core writes to this register, it provides data to be returned to the LPC Host on the next read from port 68H. The ECISTSn\_OBF bit in ECISTS1 register is also set when 8051 core writes to this register.



### 20.2.3 ECI Status Register (ECISTS)

| Location |                                                       | 7    | 6                                                                                                                                                                                                                                                                                                                                                                                                                                         | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 4                | 3              | 2  | 1              | 0              |  |  |
|----------|-------------------------------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------------|----|----------------|----------------|--|--|
| 7F54H    | Read                                                  | UD   | ECISTS_<br>SMI_EVT                                                                                                                                                                                                                                                                                                                                                                                                                        | ECISTS_<br>SCI_EVT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ECISTS_<br>BURST | ECISTS_<br>C/D | UD | ECISTS_<br>IBF | ECISTS_<br>OBF |  |  |
|          | Write                                                 |      |                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                  | -              |    | -              | -              |  |  |
|          | Reset                                                 | 0    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                | 0              | 0  | 0              | 0              |  |  |
|          | Symbol<br>-<br>UD<br>ECISTS_SMI_EVT<br>ECISTS_SCI_EVT |      |                                                                                                                                                                                                                                                                                                                                                                                                                                           | Function         Not implemented         User defined bits. Can be written/read by 8051         SMI Event flag         1: SMI event is pending         0: No outstanding SMI events         The ECISTS_SMI_EVT bit is a software controlled flag. Typically it is set when the embedded controller has detected an internal event that is to be processed by the system management interrupt SMI handler.         SCI Event flag         1: SCI event is pending         0: No outstanding SCI events         The ECISTS_SCI_EVT bit is a software controlled flag. Typically it is set when the embedded controller has detected an internal event that is to be processed by the system flag         1: SCI event is pending         0: No outstanding SCI events         The ECISTS_SCI_EVT bit is a software controlled flag. Typically it is set when the embedded controller has detected an internal event that is to be processed by the operating system driver that handles system control interrupt SCI. |                  |                |    |                |                |  |  |
|          | ECISTS_BU                                             | JRST | Burst Mode flag<br>1: EC is in Burst Mode for polled command processing<br>0: EC is in normal mode for interrupt-driven command processing<br>The ECISTSn_BURST bit is a software only controlled flag. It indicates the<br>embedded controller resources are dedicated to processing EC command/data<br>stream. Burst Mode speeds up communication with the operating system driver as<br>it eliminates the overhead of SCIs processing. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                  |                |    |                |                |  |  |
|          | ECISTS_C/                                             | D    | Command/Data flag (read only)<br>Set to '1' when the LPC Host writes command byte to port 66H<br>Cleared to '0' when the LPC Host writes data byte to port 62H                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                  |                |    |                |                |  |  |
|          | ECISTS_IBF<br>ECISTS_OBF                              |      |                                                                                                                                                                                                                                                                                                                                                                                                                                           | Input Buffer Full flag (read only)<br>Set when the LPC Host writes data or command to port 62H or 66H<br>Cleared when 8051 reads ECIDATA register at address 7F53H<br>Interrupt request ECIBF to 8051 is asserted when this bit is set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                  |                |    |                |                |  |  |
|          |                                                       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                           | Output Buffer Full flag (read only)<br>Set when 8051 writes into ECIDATA register at address 7F53H<br>Cleared when the LPC Host reads port 62H<br>Interrupt request ECOBE to 8051 is asserted when this bit is cleared                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                  |                |    |                |                |  |  |

10/06



### 20.2.4 ECI Status Register 1 (ECISTS1)

| Location |                                | 7       | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 5                                                                                                                                                                                                                                                                                                                                                                                                                                          | 4                 | 3               | 2  | 1               | 0               |  |  |
|----------|--------------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------|----|-----------------|-----------------|--|--|
| 7F81H    | Read                           | UD      | ECISTS1_<br>SMI_EVT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ECISTS1_<br>SCI_EVT                                                                                                                                                                                                                                                                                                                                                                                                                        | ECISTS1<br>_BURST | ECISTS1<br>_C/D | UD | ECISTS1<br>_IBF | ECISTS1<br>_OBF |  |  |
|          | Write                          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   | -               |    | -               | -               |  |  |
|          | Reset                          | 0       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0                 | 0               | 0  | 0               | 0               |  |  |
|          | Symbol<br>-<br>UD<br>ECISTS1_S | SMI_EVT | 0       0       0       0       0       0       0         Function         Not implemented         User defined bits. Can be read/written by 8051.         SMI Event flag         1: SMI event is pending         0: No outstanding SMI events         The SMI_EVT bit is a software only controlled flag. Typically it is set when the embedded controller detects an internal event to be processed by the system management interrupt SMI handler.         SCI Event flag         1: SCI event is pending         0: No outstanding SCI events         The ECISTS_SCI_EVT bit is a software-only controlled flag. Typically it is set when the embedded controller has detected an internal event that is to be processed by the operating system driver that handles system control interrupt SCI. |                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   |                 |    |                 |                 |  |  |
|          | ECISTS1_BURST                  |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Burst Mode flag<br>1: EC is in Burst Mode for polled command processing<br>0: EC is in normal mode for interrupt-driven command processing.<br>The ECISTSn_BURST bit is a software-only controlled flag. It indicates the<br>embedded controller resources are dedicated to processing EC command/data<br>stream. Burst Mode speeds up communication with the operating system driver as<br>it eliminates the overhead of SCIs processing. |                   |                 |    |                 |                 |  |  |
|          | ECISTS1_C                      | C/D     | Command/Data flag (read only)<br>Set to '1' when the LPC Host writes command byte to port 6CH<br>Cleared to '0' when the LPC Host writes data byte to port 68H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   |                 |    |                 |                 |  |  |
|          | ECISTS1_IBF                    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Input Buffer Full flag (read only)<br>Set when the LPC Host writes data or command to port 68H or 6CH<br>Cleared when 8051 reads ECIDATA1 register at address 7F80H<br>Interrupt request ECIBF1 to 8051 is asserted when this bit is set                                                                                                                                                                                                   |                   |                 |    |                 |                 |  |  |
|          | ECISTS1_C                      | DBF     | Output Buffer Full flag (read only)<br>Set when 8051 writes into ECIDATA1 register at address 7F80H<br>Cleared when the LPC Host reads port 68H<br>Interrupt request ECOBE1 to 8051 is asserted when this bit is cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   |                 |    |                 |                 |  |  |



# 20.3 SMI and SCI Control

In addition to the standard ACPI EC registers described in the Section 20.2, the SST79LF008 provides ECI configuration registers, which control SMI and SCI hardware generation from EC interface. As shown on Figure 20-1, both SMI and SCI interrupts are generated as active low level signals. A single SMI pin is shared by both ECI interfaces and mailbox interface as detailed in Section 21.0, and two SCI pins (EC\_SCI and EC1\_SCI) are dedicated to EC interfaces (ECI0 and ECI1, respectively).

### 20.3.1 ECI Configuration Register (ECICFG)

|          |       | J = - |   | ,      |         |        |         |        |        |
|----------|-------|-------|---|--------|---------|--------|---------|--------|--------|
| Location |       | 7     | 6 | 5      | 4       | 3      | 2       | 1      | 0      |
|          | Read  | -     | - | ECICFG | ECICFG  | ECICFG | ECICFG  | ECICFG | ECICFG |
| 7F51H    | Write |       |   | _SMIW  | _SMISEL | _SCIW  | _SCISEL | _SCIEN | _SMIEN |
|          | Reset | Х     | Х | 0      | 0       | 0      | 0       | 0      | 0      |

| Symbol        | Function                                                               |
|---------------|------------------------------------------------------------------------|
| -             | Not implemented                                                        |
| Х             | Not defined                                                            |
| ECICFG_SMIW   | SMI generation control bit                                             |
|               | 1: Generate SMI from ECI0                                              |
|               | 0: Do not generate SMI from ECI0                                       |
| ECICFG_SMISEL | SMI source selection bit                                               |
|               | 1: Select ECISTSn_OBF (ECISTS.0) as SMI source (ECISTSn_OBF = 1 will   |
|               | cause SMI if ECICFGn_SMIEN is set)                                     |
|               | 0: Select ECICFGn_SMIW (ECICFG.5) as SMI source (ECICFGn_SMIW = 1 will |
|               | cause SMI if ECICFGn_SMIEN is set)                                     |
| ECICFG_SCIW   | SCI generation control bit                                             |
|               | 1: Generate SCI from ECI0                                              |
|               | 0: Do not generate SCI from ECI0                                       |
| ECICFG_SCISEL | SCI source selection bit                                               |
|               | 1: Select ECISTSn_OBF (ECISTS.0) as SCI source (ECISTSn_OBF = 1 will   |
|               | cause SCI if ECICFGn_SCIEN is set)                                     |
|               | 0: Select ECICFGn_SCIW (ECICFG.3) as SCI source (ECICFGn_SCIW = 1 will |
|               | cause SCI if ECICFGn_SCIEN is set)                                     |
| ECICFG_SCIEN  | SCI generation enable bit                                              |
|               | 1: Enable SCI generation from ECI0                                     |
|               | 0: Disable SCI generation from ECI0                                    |
| ECICFG_SMIEN  | SMI generation enable bit                                              |
|               | 1: Enabled SMI generation from ECI0                                    |
|               | 0: Disable SMI generation from ECI0                                    |



# 20.3.2 ECI Configuration Register 1(ECICFG1)





FIGURE 20-1: SCI and SMI Generation Diagram



# 21.0 MAILBOX INTERFACE AND DATA TRANSFER BLOCK

The SST79LF008 mailbox interface provides the LPC Host and 8051 with an additional mechanism for software controlled communications. The mailbox (MBX) interface includes 32 command/data transfer registers, and 3 control registers.

Mailbox registers are accessed by the Host via a pair of Index/Data ports mapped into the LPC I/O space. The default LPC I/O address of the MBX Index port is 00H and of the MBX Data port is 01H. The default addresses can be

changed by 8051 firmware during the SST79LF008 initial configuration as described in Section 23.0. In order to access a mailbox register, the Host must write the respective access index to the MBX Index port and then read/ write data from/to the MBX data port. The 8051 can access any mailbox transfer register directly at the assigned address in the 8051 external data memory space. Refer to Table 21-1 and Table 21-2 for mailbox registers Host access indexes and 8051 memory addresses.

# 21.1 Mailbox Command/Data Transfer Registers

| Mailbox name        | Host Acess Index | 8051 Address | Function                              |
|---------------------|------------------|--------------|---------------------------------------|
| Mailbox register 0  | 82H              | 7F08H        | Host-to-8051 Mailbox command register |
| Mailbox register 1  | 83H              | 7F09H        | 8051-to-Host Mailbox command register |
| Mail box register 2 | 84H              | 7F0AH        | Mailbox data transfer register        |
| Mail box register 3 | 85H              | 7F0BH        | Mailbox data transfer register        |
| Mailbox register 4  | 86H              | 7F0CH        | Mailbox data transfer register        |
| Mailbox register 5  | 87H              | 7F0DH        | Mailbox data transfer register        |
| Mailbox register 6  | 88H              | 7F0EH        | Mailbox data transfer register        |
| Mailbox register 7  | 89H              | 7F0FH        | Mailbox data transfer register        |
| Mailbox register 8  | 8AH              | 7F10H        | Mailbox data transfer register        |
| Mailbox register 9  | 8BH              | 7F11H        | Mailbox data transfer register        |
| Mailbox register A  | 8CH              | 7F12H        | Mailbox data transfer register        |
| Mailbox register B  | 8DH              | 7F13H        | Mailbox data transfer register        |
| Mailbox register C  | 8EH              | 7F14H        | Mailbox data transfer register        |
| Mailbox register D  | 8FH              | 7F15H        | Mailbox data transfer register        |
| Mailbox register E  | 90H              | 7F16H        | Mailbox data transfer register        |
| Mailbox register F  | 91H              | 7F17H        | Mailbox data transfer register        |
| Mailbox register 10 | A0H              | 7F70H        | Mailbox data transfer register        |
| Mailbox register 11 | A1H              | 7F71H        | Mailbox data transfer register        |
| Mailbox register 12 | A2H              | 7F72H        | Mailbox data transfer register        |
| Mailbox register 13 | A3H              | 7F73H        | Mailbox data transfer register        |
| Mailbox register 14 | A4H              | 7F74H        | Mailbox data transfer register        |
| Mailbox register 15 | A5H              | 7F75H        | Mailbox data transfer register        |
| Mailbox register 16 | A6H              | 7F76H        | Mailbox data transfer register        |
| Mailbox register 17 | A7H              | 7F77H        | Mailbox data transfer register        |
| Mailbox register 18 | A8H              | 7F78H        | Mailbox data transfer register        |
| Mailbox register 19 | A9H              | 7F79H        | Mailbox data transfer register        |
| Mailbox register 1A | AAH              | 7F7AH        | Mailbox data transfer register        |
| Mailbox register 1B | ABH              | 7F7BH        | Mailbox data transfer register        |
| Mailbox register 1C | ACH              | 7F7CH        | Mailbox data transfer register        |
| Mailbox register 1D | ADH              | 7F7DH        | Mailbox data transfer register        |

TABLE 21-1: Mailbox Command/Data Transfer Registers Map



### TABLE 21-1: Mailbox Command/Data Transfer Registers Map (Continued)

| Mailbox nam      | е  | Host Acess Index | 8051 Address | Function                       |
|------------------|----|------------------|--------------|--------------------------------|
| Mailbox register | 1E | AEH              | 7F7EH        | Mailbox data transfer register |
| Mailbox register | 1F | AFH              | 7F7FH        | Mailbox data transfer register |

T21-1.1320

### 21.1.1 Mailbox register 0 (MBX0)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | MBX0_7 | MBX0_6 | MBX0_5 | MBX0_4 | MBX0_3 | MBX0_2 | MBX0_1 | MBX0_0 |
| 7F08H    | Write |        |        |        |        |        |        |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol MBX0[7:0]

### Function

Host-to-8051 Mailbox command register

When the Host writes to this register, an 8051 interrupt request MBXINT is asserted. The interrupt request is cleared when the 8051 reads data from this register. When the 8051 writes to this register, the data is ignored and the register is reset to 00H.

### 21.1.2 Mailbox register 1 (MBX1)

| Location |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
|          | Read  | MBX1_7 | MBX1_6 | MBX1_5 | MBX1_4 | MBX1_3 | MBX1_2 | MBX1_1 | MBX1_0 |
| 7F09H    | Write |        |        |        |        |        |        |        |        |
|          | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol

MBX1[7:0]

### Function

8051-to-Host Mailbox command register

When the 8051 writes to this register, a mailbox SMI source bit, MSMI\_SRC is asserted. The SMI source is cleared when the Host reads data from this register. When the Host writes to this register, the data is ignored and the register is reset to 00H.

The mailbox registers 0 and 1 can be used by the Host software and 8051 firmware to create mailbox command protocol(s), and to provide a hand-shaking mechanism for shared access to the other 30 mailbox data transfer registers.

### 21.1.3 Mailbox registers 2-1F (MBX2 - MBX1F)

| Location   |       | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|------------|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| (see Table | Read  | MBXn_7 | MBXn_6 | MBXn_5 | MBXn_4 | MBXn_3 | MBXn_2 | MBXn_1 | MBXn_0 |
| 21-1)      | Write |        |        |        |        |        |        |        |        |
|            | Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Symbol MBXn[7:0]

### Function

Mailbox data transfer register (n = 2-1F)

General purpose data transfer registers. Can be read/written by both Host and 8051



# 21.2 Mailbox Control Registers

Only the LPC Host can access the Mailbox control registers. These registers are not mapped into 8051 memory space, and therefore can only be identified by the Host access indexes. These control registers are shown in Table 21-2.

### TABLE 21-2: Mailbox Control Registers Map

| Mailbox name        | HOST ACCESS<br>INDEX | FUNCTION                                           |
|---------------------|----------------------|----------------------------------------------------|
| Mailbox register 94 | 94H                  | Host control of 8051 clock and shared flash access |
| Mailbox register 96 | 96H                  | MBX SMI source register                            |
| Mailbox register 97 | 97H                  | MBX SMI mask register                              |

T21-2.1245

### 21.2.1 Mailbox register 94 (MBX94)

| Location   |          | 7    | 6                                                                                                                                                                     | 5                                                                                                                                                                                                                                                | 4                                                                                                                                                                                                                         | 3                                                                                                                                                                                            | 2                                                                                                                                                             | 1                                                                                                                          | 0                                                                                                                       |  |  |  |
|------------|----------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--|--|--|
| (see Table | Read     | IDLE | HOST-<br>FLASH                                                                                                                                                        | -                                                                                                                                                                                                                                                | MAP                                                                                                                                                                                                                       | EXECU-<br>TION                                                                                                                                                                               | -                                                                                                                                                             | -                                                                                                                          | STP_CLK                                                                                                                 |  |  |  |
| 21-2)      | Write    | -    | -                                                                                                                                                                     |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                           | -                                                                                                                                                                                            |                                                                                                                                                               |                                                                                                                            |                                                                                                                         |  |  |  |
|            | Reset    | 0    | 0                                                                                                                                                                     | Х                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                         | 0                                                                                                                                                                                            | Х                                                                                                                                                             | Х                                                                                                                          | 0                                                                                                                       |  |  |  |
|            | Symbol   |      | Functio                                                                                                                                                               | on                                                                                                                                                                                                                                               |                                                                                                                                                                                                                           |                                                                                                                                                                                              |                                                                                                                                                               |                                                                                                                            |                                                                                                                         |  |  |  |
|            | -        |      | Not imp                                                                                                                                                               | lemented                                                                                                                                                                                                                                         |                                                                                                                                                                                                                           |                                                                                                                                                                                              |                                                                                                                                                               |                                                                                                                            |                                                                                                                         |  |  |  |
|            | Х        |      | Not def                                                                                                                                                               | ined                                                                                                                                                                                                                                             |                                                                                                                                                                                                                           |                                                                                                                                                                                              |                                                                                                                                                               |                                                                                                                            |                                                                                                                         |  |  |  |
|            | IDLE     |      |                                                                                                                                                                       | lle mode sta                                                                                                                                                                                                                                     | •                                                                                                                                                                                                                         |                                                                                                                                                                                              |                                                                                                                                                               |                                                                                                                            |                                                                                                                         |  |  |  |
|            |          |      |                                                                                                                                                                       | is in Idle m                                                                                                                                                                                                                                     |                                                                                                                                                                                                                           |                                                                                                                                                                                              |                                                                                                                                                               |                                                                                                                            |                                                                                                                         |  |  |  |
|            |          |      |                                                                                                                                                                       | is not in Idle                                                                                                                                                                                                                                   |                                                                                                                                                                                                                           |                                                                                                                                                                                              |                                                                                                                                                               |                                                                                                                            |                                                                                                                         |  |  |  |
|            | HOSTFLAS | SH   |                                                                                                                                                                       | terface owr                                                                                                                                                                                                                                      |                                                                                                                                                                                                                           |                                                                                                                                                                                              |                                                                                                                                                               |                                                                                                                            |                                                                                                                         |  |  |  |
|            |          |      | -                                                                                                                                                                     | 1: LPC Host owns flash interface                                                                                                                                                                                                                 |                                                                                                                                                                                                                           |                                                                                                                                                                                              |                                                                                                                                                               |                                                                                                                            |                                                                                                                         |  |  |  |
|            |          |      |                                                                                                                                                                       | owns flash                                                                                                                                                                                                                                       |                                                                                                                                                                                                                           |                                                                                                                                                                                              |                                                                                                                                                               |                                                                                                                            |                                                                                                                         |  |  |  |
|            |          |      | This bit is set when the shared flash interface is released to the host because                                                                                       |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                           |                                                                                                                                                                                              |                                                                                                                                                               |                                                                                                                            |                                                                                                                         |  |  |  |
|            |          |      |                                                                                                                                                                       | either (a) 8051 is running from the scratch ROM and the HOST_ACCESS bit in the SFSC register is set, or (b) 8051 is in Idle mode and 8051 core clock is stopped by                                                                               |                                                                                                                                                                                                                           |                                                                                                                                                                                              |                                                                                                                                                               |                                                                                                                            |                                                                                                                         |  |  |  |
|            |          |      |                                                                                                                                                                       |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                           |                                                                                                                                                                                              |                                                                                                                                                               |                                                                                                                            |                                                                                                                         |  |  |  |
|            |          |      | SFSC                                                                                                                                                                  | egister is se                                                                                                                                                                                                                                    | et, or (b) 805                                                                                                                                                                                                            | 1 is in Idle mo                                                                                                                                                                              | ode and 80                                                                                                                                                    |                                                                                                                            |                                                                                                                         |  |  |  |
|            |          |      | SFSC i<br>setting                                                                                                                                                     | egister is se<br>the STP_CL                                                                                                                                                                                                                      | et, or (b) 805<br>_K bit in MB                                                                                                                                                                                            |                                                                                                                                                                                              | ode and 80                                                                                                                                                    |                                                                                                                            |                                                                                                                         |  |  |  |
|            | MAP      |      | SFSC i<br>setting<br>KBC fla                                                                                                                                          | egister is se<br>the STP_CL<br>sh mapping                                                                                                                                                                                                        | et, or (b) 805<br>K bit in MB<br>control bit                                                                                                                                                                              | 1 is in Idle ma<br>X94 (this regi                                                                                                                                                            | ode and 80                                                                                                                                                    |                                                                                                                            |                                                                                                                         |  |  |  |
|            | MAP      |      | SFSC i<br>setting<br>KBC fla<br>1: KBC                                                                                                                                | egister is se<br>the STP_CL<br>sh mapping<br>flash area is                                                                                                                                                                                       | et, or (b) 805<br>LK bit in MB<br>g control bit<br>s mapped to                                                                                                                                                            | 1 is in Idle mo<br>X94 (this regi<br>DLPC space                                                                                                                                              | ode and 80<br>ster).                                                                                                                                          | 51 core cloc                                                                                                               | k is stopped b                                                                                                          |  |  |  |
|            | MAP      |      | SFSC i<br>setting<br>KBC fla<br>1: KBC<br>0: KBC                                                                                                                      | egister is se<br>the STP_CL<br>ish mapping<br>flash area is<br>flash area is                                                                                                                                                                     | et, or (b) 805<br>LK bit in MB<br>g control bit<br>s mapped to                                                                                                                                                            | 1 is in Idle ma<br>X94 (this regi                                                                                                                                                            | ode and 80<br>ster).                                                                                                                                          | 51 core cloc                                                                                                               | k is stopped b                                                                                                          |  |  |  |
|            | MAP      |      | SFSC i<br>setting<br>KBC fla<br>1: KBC<br>0: KBC<br>returns                                                                                                           | egister is se<br>the STP_CL<br>ish mapping<br>flash area is<br>flash area is<br>00H)                                                                                                                                                             | et, or (b) 805<br>LK bit in MB<br>g control bit<br>s mapped to<br>s not mappe                                                                                                                                             | 1 is in Idle mo<br>X94 (this regi<br>DLPC space<br>ad to LPC spa                                                                                                                             | ode and 809<br>ster).<br>ace (LPC re                                                                                                                          | 51 core cloc                                                                                                               | k is stopped b<br>to KBC area                                                                                           |  |  |  |
|            | MAP      |      | SFSC i<br>setting<br>KBC fla<br>1: KBC<br>0: KBC<br>returns<br>The KE                                                                                                 | egister is se<br>the STP_CL<br>ish mapping<br>flash area is<br>flash area is<br>00H)<br>iC flash area                                                                                                                                            | et, or (b) 805<br>LK bit in MB<br>g control bit<br>s mapped to<br>s not mappe<br>a is Block0-E                                                                                                                            | 1 is in Idle ma<br>X94 (this reginned<br>DLPC space<br>and to LPC spa<br>Block1 = 128                                                                                                        | ode and 80<br>ster).<br>ace (LPC re<br>KByte, or I                                                                                                            | 51 core cloc<br>ead access t<br>Block0 = 64                                                                                | k is stopped b<br>to KBC area<br>KByte                                                                                  |  |  |  |
|            | MAP      |      | SFSC i<br>setting<br>KBC fla<br>1: KBC<br>0: KBC<br>0: KBC<br>returns<br>The KE<br>depend                                                                             | egister is se<br>the STP_CL<br>ish mapping<br>flash area is<br>flash area is<br>00H)<br>iC flash area<br>ling on the s                                                                                                                           | et, or (b) 805<br>K bit in MB<br>control bit<br>s mapped to<br>s not mappe<br>a is Block0-E<br>tatus of AC                                                                                                                | 1 is in Idle ma<br>X94 (this regineration<br>LPC space<br>and to LPC spa<br>Block1 = 128<br>DN[1] bit – se                                                                                   | ode and 80<br>ster).<br>ace (LPC re<br>KByte, or I<br>se Section 6                                                                                            | 51 core cloc<br>ead access 1<br>Block0 = 64<br>5.5. Note tha                                                               | k is stopped b<br>to KBC area<br>KByte<br>at if the 8051                                                                |  |  |  |
|            | MAP      |      | SFSC i<br>setting<br>KBC fla<br>1: KBC<br>0: KBC<br>returns<br>The KE<br>depenc<br>doesn't                                                                            | egister is se<br>the STP_CL<br>ish mapping<br>flash area is<br>flash area is<br>00H)<br>iC flash area<br>ling on the s<br>map KBC f                                                                                                              | et, or (b) 805<br>LK bit in MB<br>g control bit<br>s mapped to<br>s not mappe<br>a is Block0-E<br>tatus of AC<br>lash area to                                                                                             | 1 is in Idle ma<br>X94 (this regi<br>DLPC space<br>ad to LPC spa<br>Block1 = 128<br>DN[1] bit – se<br>the LPC spa                                                                            | ode and 80<br>ster).<br>ace (LPC re<br>KByte, or f<br>se Section 6<br>ce, then thi                                                                            | 51 core cloc<br>ead access t<br>Block0 = 64<br>5.5. Note tha<br>s bit is ignor                                             | k is stopped b<br>to KBC area<br>KByte<br>at if the 8051<br>ed. If the 805 <sup>-1</sup>                                |  |  |  |
|            | MAP      |      | SFSC i<br>setting<br>KBC fla<br>1: KBC<br>0: KBC<br>returns<br>The KE<br>depend<br>doesn't<br>maps t                                                                  | egister is se<br>the STP_CL<br>ish mapping<br>flash area is<br>flash area is<br>00H)<br>iC flash area<br>ing on the s<br>map KBC f<br>he KBC flash                                                                                               | et, or (b) 805<br>LK bit in MB<br>g control bit<br>s mapped to<br>s not mappe<br>a is Block0-E<br>tatus of AC<br>lash area to<br>n to the LPC                                                                             | 1 is in Idle ma<br>X94 (this regi<br>DLPC space<br>ad to LPC spa<br>Block1 = 128<br>DN[1] bit – se<br>the LPC spa<br>space, then                                                             | ode and 80<br>ster).<br>ace (LPC re<br>KByte, or f<br>se Section 6<br>ce, then thi                                                                            | 51 core cloc<br>ead access t<br>Block0 = 64<br>5.5. Note tha<br>s bit is ignor                                             | k is stopped b<br>to KBC area<br>KByte<br>at if the 8051<br>ed. If the 805 <sup>-1</sup>                                |  |  |  |
|            |          | N    | SFSC i<br>setting<br>KBC fla<br>1: KBC<br>0: KBC<br>returns<br>The KE<br>depend<br>doesn't<br>maps th<br>area is                                                      | egister is se<br>the STP_CL<br>ish mapping<br>flash area is<br>flash area is<br>00H)<br>C flash area<br>ing on the s<br>map KBC f<br>ne KBC flash<br>visible to the                                                                              | et, or (b) 805<br>K bit in MB.<br>control bit<br>s mapped to<br>s not mappe<br>a is Block0-E<br>tatus of ACC<br>lash area to<br>n to the LPC<br>e LPC Host                                                                | 1 is in Idle ma<br>X94 (this reginant<br>DEPC space<br>and to LPC spa<br>Block1 = 128<br>DN[1] bit - se<br>the LPC spa<br>space, then<br>or not.                                             | ode and 80<br>ster).<br>Ace (LPC re<br>KByte, or I<br>ee Section 6<br>ce, then thi<br>this bit cont                                                           | 51 core cloc<br>ead access t<br>Block0 = 64<br>5.5. Note tha<br>s bit is ignor                                             | k is stopped b<br>to KBC area<br>KByte<br>at if the 8051<br>ed. If the 805 <sup>-1</sup>                                |  |  |  |
|            | MAP      | Ν    | SFSC f<br>setting<br>KBC fla<br>1: KBC<br>0: KBC<br>0: KBC<br>The KE<br>depend<br>doesn't<br>maps th<br>area is<br>LPC pr                                             | egister is se<br>the STP_CL<br>ish mapping<br>flash area is<br>00H)<br>iC flash area<br>ling on the s<br>map KBC flash<br>visible to the<br>ogram/erase                                                                                          | et, or (b) 805<br>K bit in MB<br>control bit<br>s mapped to<br>s not mapped<br>a is Block0-E<br>tatus of AC<br>lash area to<br>n to the LPC<br>e LPC Host<br>e operation a                                                | 1 is in Idle ma<br>X94 (this regi<br>DLPC space<br>ad to LPC spa<br>Block1 = 128<br>DN[1] bit – se<br>the LPC spa<br>space, then<br>or not.<br>acceptance ir                                 | ode and 80<br>ster).<br>ace (LPC re<br>KByte, or f<br>ee Section 6<br>ce, then thi<br>this bit cont                                                           | 51 core cloc<br>ead access f<br>Block0 = 64<br>5.5. Note tha<br>s bit is ignor<br>rols whethe                              | k is stopped b<br>to KBC area<br>KByte                                                                                  |  |  |  |
|            |          | N    | SFSC f<br>setting<br>KBC fla<br>1: KBC<br>0: KBC<br>returns<br>The KE<br>depenc<br>doesn't<br>area is<br>LPC pr<br>1: Last                                            | egister is se<br>the STP_CL<br>ish mapping<br>flash area is<br>00H)<br>iC flash area<br>ling on the s<br>map KBC flash<br>visible to the<br>ogram/erase<br>LPC Host tr                                                                           | et, or (b) 805<br>K bit in MB<br>control bit<br>s mapped to<br>s not mapped<br>a is Block0-E<br>tatus of AC<br>lash area to<br>n to the LPC<br>e LPC Host<br>operation a<br>iggered prog                                  | 1 is in Idle ma<br>X94 (this regi<br>DLPC space<br>ad to LPC spa<br>Block1 = 128<br>DN[1] bit – se<br>the LPC spa<br>space, then<br>or not.<br>acceptance ir<br>gram/erase o                 | ode and 80<br>ster).<br>ace (LPC re<br>KByte, or f<br>ee Section 6<br>ce, then thi<br>this bit cont<br>ndicator<br>peration is                                | 51 core cloc<br>ead access 1<br>Block0 = 64<br>5.5. Note tha<br>s bit is ignor<br>rols whethe<br>accepted                  | k is stopped b<br>to KBC area<br>KByte<br>at if the 8051<br>red. If the 805 <sup>-1</sup><br>r the KBC flas             |  |  |  |
|            | EXECUTIO | Ν    | SFSC f<br>setting<br>KBC fla<br>1: KBC<br>0: KBC<br>returns<br>The KE<br>depend<br>doesn't<br>maps tf<br>area is<br>LPC pr<br>1: Last<br>0: Last                      | egister is set<br>the STP_CL<br>ish mapping<br>flash area is<br>flash area is<br>00H)<br>C flash area<br>ling on the s<br>map KBC flash<br>visible to the<br>ogram/erase<br>LPC Host tr<br>LPC Host tr                                           | et, or (b) 805<br>K bit in MB<br>control bit<br>s mapped to<br>s not mapped<br>a is Block0-E<br>tatus of AC<br>lash area to<br>n to the LPC<br>e LPC Host<br>e operation a<br>iggered pro-                                | 1 is in Idle ma<br>X94 (this regi<br>DLPC space<br>ad to LPC spa<br>Block1 = 128<br>DN[1] bit – se<br>the LPC spa<br>space, then<br>or not.<br>acceptance ir                                 | ode and 80<br>ster).<br>ace (LPC re<br>KByte, or f<br>ee Section 6<br>ce, then thi<br>this bit cont<br>ndicator<br>peration is                                | 51 core cloc<br>ead access 1<br>Block0 = 64<br>5.5. Note tha<br>s bit is ignor<br>rols whethe<br>accepted                  | k is stopped b<br>to KBC area<br>KByte<br>at if the 8051<br>red. If the 805<br>r the KBC flas                           |  |  |  |
|            |          | Ν    | SFSC i<br>setting<br>KBC fla<br>1: KBC<br>0: KBC<br>returns<br>The KE<br>depend<br>doesn't<br>maps th<br>area is<br>LPC pr<br>1: Last<br>0: Last<br>Stop 80           | egister is set<br>the STP_CL<br>ish mapping<br>flash area is<br>flash area is<br>00H)<br>iC flash area<br>ing on the s<br>map KBC f<br>he KBC flash<br>visible to the<br>ogram/erase<br>LPC Host tr<br>LPC Host tr<br>ST clock ree               | et, or (b) 805<br>K bit in MB<br>control bit<br>s mapped to<br>s not mapped<br>a is Block0-E<br>tatus of ACC<br>lash area to<br>n to the LPC<br>e LPC Host<br>e operation a<br>iggered pro-<br>iggered pro-<br>guest bit  | 1 is in Idle ma<br>X94 (this regi<br>DLPC space<br>ad to LPC spa<br>Block1 = 128<br>DN[1] bit – se<br>the LPC spa<br>space, then<br>or not.<br>acceptance ir<br>gram/erase o<br>gram/erase o | ode and 80<br>ster).<br>ace (LPC re<br>KByte, or B<br>ee Section 6<br>ce, then thi<br>this bit cont<br>ndicator<br>peration is<br>peration ha                 | 51 core cloc<br>ead access t<br>Block0 = 64<br>5.5. Note that<br>s bit is ignor<br>rols whethe<br>accepted<br>as been igno | k is stopped b<br>to KBC area<br>KByte<br>at if the 8051<br>red. If the 805<br>r the KBC flas                           |  |  |  |
|            | EXECUTIO | N    | SFSC i<br>setting<br>KBC fla<br>1: KBC<br>0: KBC<br>returns<br>The KE<br>depend<br>doesn't<br>maps tl<br>area is<br>LPC pr<br>1: Last<br>0: Last<br>Stop 80<br>Set by | egister is se<br>the STP_CL<br>ish mapping<br>flash area is<br>flash area is<br>00H)<br>C flash area<br>ing on the s<br>map KBC f<br>he KBC flash<br>visible to the<br>ogram/erase<br>LPC Host tr<br>LPC Host tr<br>DS1 clock rea<br>he LPC Host | et, or (b) 805<br>K bit in MB<br>control bit<br>s mapped to<br>s not mapped<br>a is Block0-E<br>tatus of ACC<br>lash area to<br>n to the LPC<br>e LPC Host<br>e operation a<br>iggered pro-<br>guest bit<br>st to stop 80 | 1 is in Idle ma<br>X94 (this regi<br>DLPC space<br>ad to LPC spa<br>Block1 = 128<br>DN[1] bit – se<br>the LPC spa<br>space, then<br>or not.<br>acceptance ir<br>gram/erase o<br>gram/erase o | ode and 80<br>ster).<br>ace (LPC re<br>KByte, or I<br>ee Section 6<br>ce, then thi<br>this bit cont<br>ndicator<br>peration is<br>peration ha<br>rder to gain | 51 core cloc<br>ead access t<br>Block0 = 64<br>5.5. Note that<br>s bit is ignor<br>rols whethe<br>accepted<br>us been igno | k is stopped b<br>to KBC area<br>KByte<br>at if the 8051<br>red. If the 805<br>r the KBC flas<br>ored<br>ne shared flas |  |  |  |



### 21.2.2 Mailbox register 96 (MBX96)

| Location            |       | 7 | 6 | 5 | 4 | 3            | 2 | 1 | 0 |
|---------------------|-------|---|---|---|---|--------------|---|---|---|
| (see Table<br>21-2) | Read  | - | - | - | - | MSMI_SR<br>C | - | - | - |
|                     | Write |   |   |   |   | -            |   |   |   |
|                     | Reset | Х | Х | Х | Х | 0            | Х | Х | Х |

Symbol

### Function

| Not implemented                                         |
|---------------------------------------------------------|
| Not defined                                             |
| Mailbox SMI source bit                                  |
| Set when 8051 writes to 8051-to-Host Mailbox register 1 |
| Cleared when the LPC Host reads Mailbox register 1      |
|                                                         |

### 21.2.3 Mailbox register 97 (MBX97)

| Location   |       | 7 | 6 | 5 | 4 | 3      | 2 | 1 | 0 |
|------------|-------|---|---|---|---|--------|---|---|---|
| (see Table | Read  | - | - | - | - | MSMI_M | - | - | - |
| 21-2)      | Write |   |   |   |   | SK     |   |   |   |
|            | Reset | Х | Х | Х | Х | 0      | Х | Х | Х |

### Symbol

-Х

### Function

Not implemented

Not defined

MSMI\_MSK

Mailbox SMI mask

1: Mask Mailbox SMI

0: Enable Mailbox SMI

This bit affects both possible mechanisms for Mailbox SMI reporting (SMI# pin and Serialized IRQ2).



# 22.0 SERIALIZED INTERRUPTS

The SST79LF008 device provides serialized interrupt output, SERIRQ, which can be used to report interrupts from SST79LF008 to the LPC Host according to the *Serialized IRQ Specification for PCI Systems, Revision 6.0.* 

# 22.1 Serialized IRQ Cycle Overview

An example of the Serialized IRQ cycle is shown on Figure 22-1. The cycle always begins with the Start frame and ends with the Stop frame. There are maximum 32 IRQ/ Data frames between the start and stop frame. Each of the

data frames includes three phases: Sample phase, Recovery phase, and Turn-around phase. The SERIRQ is considered *Idle* between Stop and Start Frames. The SERIRQ is *Active* between Start and Stop Frames.

| SL START FRAME IRQ0 FRAME IRQ1 FRAME IRQ2 FRAME<br>or H H R T S R T S R T S R T                                                                                                                                                                                       |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                       |
| SERIRQ START <sup>1</sup>                                                                                                                                                                                                                                             |
| DRIVER IRQ1 HOST CONTROLLER NONE IRQ1 NONE                                                                                                                                                                                                                            |
| IRQ14 FRAME       IRQ15 FRAME       IOCHCK#FRAME       STOP FRAME       NEXT CYCLE         S       R       T       S       R       T       I <sup>2</sup> H       R       T                                                                                           |
|                                                                                                                                                                                                                                                                       |
| SERIRQ STOP <sup>3</sup> START <sup>4</sup>                                                                                                                                                                                                                           |
| DRIVER NONE IRQ15 NONE HOST CONTROLLER                                                                                                                                                                                                                                |
| Legend: H = Host Control SL = Slave Control R = Recovery T = Turn-around S = Sample                                                                                                                                                                                   |
| 1. Start Frame pulse can be 4-8 clocks wide.                                                                                                                                                                                                                          |
| 2. There may be none, or one or more idles states (I) during the STOP frame.                                                                                                                                                                                          |
| <ol> <li>Stop Frame is two clocks wide for Quiet mode, three clocks wide for continuous mode.</li> <li>The next SERIRQ cycle's Start Frame pulse may or may not start immediately after the turn-around of the Stop frame.</li> <li>1245 SerialIRQ cycle.0</li> </ol> |

FIGURE 22-1: Serialized IRQ cycle.

# 22.2 Serialized IRQ Start Frame

There are two modes of operation for the generation of SERIRQ Start Frame: Continuous and Quiet mode.

In Continuous mode, the SST79LF008 does not generate a Start Frame. The device just monitors SERIRQ input and waits for the LPC Host to initiate the Start Frame by driving SERIRQ line low for four to eight clocks.

In Quite mode, the SST79LF008 generates the Start Frame when it detects any transition of the internal IRQ/ Data signals associated with serialized IRQs, see Section 22.3. The device will not generate the start frame if the SERIRQ is already Active, and the IRQ/Data transition can be reported in the current SERIRQ Cycle.

In order to initiate the Start Frame, the SST79LF008 drives the SERIRQ line low for one clock, and then immediately tri-states the line. The Host controller takes over driving the SERIRQ low during the next clock and will continue driving it for a period of three to seven clocks. Thus a total Start Frame low pulse width is from four to eight clocks.



After SST79LF008 chip reset, as well as after LPC Interface reset, the SST79LF008 is in the Continuous mode, therefore only the LPC Host can initiate the first Start Frame. A SERIRQ mode transition can only occur during the Stop Frame as described in Section 22.4.

# 22.3 Serialized IRQ Data Frame

After a Start Frame low going edge has been initiated, SST79LF008 waits for the rising edge of the start pulse in order to start counting IRQ/Data Frames. Each IRQ/Data Frame has three clocks: Sample phase, Recovery phase, and Turn-around phase. During the sample phase, the SST79LF008 drives the SERIRQ pin low provided the last sampled IRQ/Data value associated with the respective frame was low. If the last sampled IRQ/Data value was high, or no IRQ/Data signal is associated with the respective frame, the SERIRQ line is left tri-stated. During the recovery phase, the SST79LF008 drives the SERIRQ high, if and only if, it had driven the SERIRQ low during the previous sample phase. During the turn-around phase, the SST79LF008 tri-states the SERIRQ. The above rules of Data Frame control are followed by the SST79LF008 regardless of which device has initiated the Start Frame.

The Sample phase for each IRQ/Data follows the low to high transition of the Start Frame pulse by a number of clocks equal to the IRQ/Data Frame number times three, minus one. The only three internal IRQ/Data signals that are actually sampled by the SST79LF008 are: KIRQ (associated typically with IRQ1 frame via configuration registers described in Section 23.0), MIRQ (associated typically with IRQ12 frame via configuration registers described in Section 23.0), and Mailbox SMI (associated with IRQ2 frame if SMIEN\_IRQ2 bit in configuration space is set). Table 22-1 shows the default SERIRQ sampling periods for these three internal IRQ/Data signals. For all other non-associated frames the SERIRQ line is left tri-stated by the SST79LF008.

| IRQ/Data Frame number | Reported System IRQ | SST79LF008 Signal Sampled | Number of clocks past<br>Start |
|-----------------------|---------------------|---------------------------|--------------------------------|
| 2                     | IRQ1                | KIRQ (Section 18.0)       | 5                              |
| 3                     | IRQ2                | MSMI_SRC (Section 20.0)   | 8                              |

MIRQ (Section 18.0)

### TABLE 22-1: SST79LF008 SERIRQ Sampling Periods

IRQ12

T22-1.1245

38

# 22.4 Serialized IRQ Stop Frame

13

After all IRQ/Data Frames are completed the SERIRQ cycle is terminated by a Stop Frame, which is indicated by the SERIRQ line being kept low for two or three clocks. Only the Host controller can initiate the Stop Frame. If the Stop Frame low time is two clocks, then the next SERIRQ cycle is in the Quiet mode, and the SST79LF008 may ini-

tiate a Start Frame. If the Stop Frame low time is three clocks, then the next SERIRQ cycle is in the Continuous mode, and only the Host may initiate a Start Frame. In any mode, the next Start Frame can be initiated once two or more clocks have occurred after the rising edge of the Stop Frame's pulse.



# 23.0 SST79LF008 CONFIGURATION

The SST79LF008 configuration module provides 8051 firmware with a flexible mechanism to relocate I/O interfaces within the LPC Host I/O address space.

# 23.1 Access to Configuration Registers

The 8051 access to configuration space is controlled by the SELCFG bit in the LPC bus monitor register, LPC-MON. Any configuration register is accessed via a pair of CFGINDEX and CFGDATA ports. The LPCMON, CFGIN-DEX PORT and CFGDATA PORT registers are mapped into the 8051 external data memory address space as shown in Registers 23.1.1-23.1.3.

### 23.1.1 LPC Bus Monitor Register (LPCMON)

| Location |       | 7      | 6    | 5 | 4 | 3 | 2 | 1       | 0     |
|----------|-------|--------|------|---|---|---|---|---------|-------|
|          | Read  | SELCFG | LPC- |   |   |   |   | LRST-   | LPCPD |
| 7F8AH    | Write |        | MODE | - | - | - | - | COREENB | -     |
|          | Reset | 0      | 0    | Х | Х | Х | Х | 0       | -     |

| Symbol      | Function                                                                              |
|-------------|---------------------------------------------------------------------------------------|
| -           | Not implemented                                                                       |
| Х           | Not defined                                                                           |
| SELCGF      | Configuration space access control bit                                                |
|             | 1: Reserved. Do not use this setting.                                                 |
|             | 0: Enable 8051 access to configuration registers (must always be enabled).            |
| LPCMODE     | LPC Memory cycle control bit                                                          |
|             | 1: SST79LF008 responds to LPC Memory cycles on LPC bus. Firmware Memory               |
|             | cycles are ignored.                                                                   |
|             | 0: SST79LF008 responds to Firmware Memory cycles on LPC bus. LPC Memory               |
|             | cycles are ignored.                                                                   |
| LRSTCOREENB | LPC Soft reset control bit                                                            |
|             | 1: LPC commands "Force/Release LPC Soft Reset" are ignored.                           |
|             | <ol><li>LPC commands "Force/Release LPC Soft Reset" are accepted.</li></ol>           |
|             | This bit can be set by 8051 firmware, but it is cleared only by SST79LF008 chip       |
|             | reset.                                                                                |
| LPCPD       | LPCPD signal status flag (read only)                                                  |
|             | This bit is equal to the inverse of LPCPD# input pin (reset value is not specified as |
|             | it is passed through pin state).                                                      |

### 23.1.2 Configuration INDEX PORT Register (CFGINDEX)

| Location |       | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
|----------|-------|----------|----------|----------|----------|----------|----------|----------|----------|
|          | Read  | CFGINDEX |
| 7F8CH    | Write | _7       | _6       | _5       | _4       | _3       | _2       | _1       | _0       |
|          | Reset | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |

Symbol CFGINDEX[7:0] Function

Configuration register index



### 23.1.3 Configuration DATA PORT Register (CFGDATA)

| Location |       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|-------|---------|---------|---------|---------|---------|---------|---------|---------|
|          | Read  | CFGDATA |
| 7F8DH    | Write | _7      | _6      | _5      | _4      | _3      | _2      | _1      | _0      |
|          | Reset | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Symbol

### Function

CFGDATA[7:0]

### Configuration register data

Configuration Registers Map is shown in the Table 23-1.

To access any Global Configuration register (index 00H-2FH) the 8051 firmware should do the following.

1. Write the index of the configuration register into the CFGINDEX PORT.

2. Write/read the Global Configuration register through the CFGDATA PORT. To access any Device Configuration register (index 30H and above) the 8051 firmware should do one of the following steps.

a)

1. Write 07H (the index of the Logical Device Number register) to the CFGINDEX PORT.

2. Write the number of the targeted logical device to the CFGDATA PORT.b)

1. Write the address of the Device Configuration register to the CFGINDEX PORT.

2. Write/read the Device Configuration register through the CFGDATA PORT.



# 23.2 Configuration Registers Description

| المراجب               | A             | Depart Malue ?           | Configuration Deviator Name                                                                                                                                                                                                          |
|-----------------------|---------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Index                 | Access Type   | Reset Value <sup>2</sup> | Configuration Register Name                                                                                                                                                                                                          |
| GLOBAL CO             | NFIGURATION   | REGISTERS                |                                                                                                                                                                                                                                      |
| 07H                   | R/W           | 00H                      | Logical Device Number <sup>3</sup>                                                                                                                                                                                                   |
| 20H                   | R             | BFH                      | Manufacturer ID (read only)                                                                                                                                                                                                          |
| 21H                   | R             | F0H                      | Device ID (read only)                                                                                                                                                                                                                |
| 22H                   | R             | Revision<br>Number       | Device Revision (read only)                                                                                                                                                                                                          |
| 25H                   | W             | 00H                      | Chip Control register 0<br>Bits [7:1] are reserved<br>Bit 0 = 1: Soft reset of Configuration registers <sup>4</sup>                                                                                                                  |
| 26H                   | R/W           | 00H                      | Chip Control register 1<br>Bits [7:1] are reserved<br>Bit 0 = SMIEN_IRQ2<br>1: Frame 3 of the SERIRQ cycle (IRQ2) is used to report Mailbox SMI.<br>0: SMI# pin is used to report Mailbox SMI                                        |
|                       | VICE 0 CONFIC | GURATION REG             | ISTERS (KEYBOARD CONTROLLER)                                                                                                                                                                                                         |
| 30H                   | R/W           | 00H                      | 01H = Device is active<br>00H = Device is inactive. The address of the device is not decoded. LPC I/O<br>read and write cycles to the device are ignored. No SERIRQ data frames is<br>associated with keyboard and mouse interrupts. |
| 60H <sup>5</sup> ,61H | R/W           | 00H,60H                  | Keyboard Data port LPC I/O address = 0000:A[11:3]:000<br>Command/Status port address = Data port address + 4                                                                                                                         |
| 70H                   | R/W           | 01H                      | Keyboard Interrupt selection (no effect if Device is inactive)                                                                                                                                                                       |
| 72H                   | R/W           | 0CH                      | Mouse Interrupt selection (not effect if Device is inactive)                                                                                                                                                                         |
| LOGICAL DE            | VICE 1 CONFIC | <b>GURATION REG</b>      | ISTERS (ACPI ECI0)                                                                                                                                                                                                                   |
| 30H                   | R/W           | 00H                      | 01H = Device is active<br>00H = Device is inactive. The address of device is not decoded. LPC I/O read<br>and write cycles to the device are ignored.                                                                                |
| 60H⁵,61H              | R/W           | 00H,62H                  | ACPI ECI0 Data port LPC I/O address = 0000:A[11:3]:0:A1:0<br>Command/Status port address = Data port address + 4                                                                                                                     |
| LOGICAL DE            | VICE 2 CONFIG | <b>GURATION REG</b>      | ISTERS (Mailbox 32 Byte Data Block)                                                                                                                                                                                                  |
| 30H                   | R/W           | 00H                      | 01H = Device is active<br>00H = Device is inactive. The address of device is not decoded. LPC I/O read<br>and write cycles to the device are ignored.                                                                                |
| 60H⁵,61H              | R/W           | 00H,00H                  | Mailbox Index port LPC I/O address = 0000:A[11:1]:0<br>Mailbox Data port address = Index port address + 1                                                                                                                            |



| Index                  | Access Type   | Reset Value <sup>2</sup> | Configuration Register Name                                                                                                                            |
|------------------------|---------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| LOGICAL DE             | VICE 3 CONFIG | <b>GURATION REG</b>      | ISTERS (ACPI ECI1)                                                                                                                                     |
| 30H                    | R/W           | 00H                      | 01H = Device is active.<br>00H = Device is inactive; the address of device is not decoded; LPC I/O read<br>and write cycles to the device are ignored. |
| 60H <sup>5</sup> , 61H | R/W           | 00H, 68H                 | ACPI ECI1 Data port LPC I/O address 0000:A[11:3]:0:A1:0<br>Command/Status port address = Data port address + 4                                         |

### TABLE 23-1: Configuration Registers Map<sup>1</sup> (Continued)

1. Register at indexes not listed in the map are reserved and must not be written to by software.

T23-1.1320

2. All configuration registers are returned to their reset values specified above after the following reset events: Power-On Reset, External reset, Watchdog timer reset, Brown-Out reset, aLPC Soft reset, LPC Soft reset, and Configuration Soft reset (see also Section 5.2).

3. A write to this register selects the current logical device. This allows access to the control and configuration registers for each logical device. All accesses to device specific configuration registers with index above 30H (including the activate command) operate only on the selected logical device.

4. The hardware automatically clears this bit after soft reset is completed; there is no need for software to clear this bit. This soft reset only affects configuration registers.

5. Register at index 60H contains high byte of LPC I/O address - bits A[15:8], and register at index 61H contains low byte of LPC I/O address- bits A[7:0].



# 24.0 ELECTRICAL SPECIFICATION

# 24.1 Absolute Maximum Stress Ratings

**Absolute Maximum Stress Ratings** (Applied conditions greater than those listed under "Absolute Maximum Stress Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these conditions or conditions greater than those defined in the operational sections of this datasheet is not implied. Exposure to absolute maximum stress rating conditions may affect device reliability.)

Temperature Under Bias-55°C to +125°C

Storage Temperature65°C to +150°C

Supply Voltage on  $V_{DD}$  and  $AV_{DD}$  Pins to Ground Potential-0.3V to 3.8V

D.C. Voltage on Any Pin with IPCI, IOPCI and IODPCI buffer type<sup>1</sup> to Ground Potential-0.5V to VDD+0.5V

Transient Voltage (<20 ns) on Any Pin with IOPCI and IODPCI buffer type to Ground Potential-2.0V to VDD+2.0V

Voltage on Any Pin with AIO4 buffer type to Ground Potential-0.3V to AVDD

Voltage on Any Other Pin to Ground Potential-0.3V to 5.5V

Package Power Dissipation Capability (Ta=25°C)1.0W

Surface Mount Solder Reflow Temperature 260°C for 10 seconds

Output Short Circuit Current<sup>2</sup>50 mA

1. Refer to Table 2-1 for pin buffer type assignments.

2. Outputs shorted for no more than one second. No more than one output shorted at a time.

# 24.2 Operating Conditions

### TABLE24-1: Operating Range

| Range      | Ambient Temp  | Vdd      | AVDD                    | Fosc      | Feclk                                          |
|------------|---------------|----------|-------------------------|-----------|------------------------------------------------|
| Commercial | 0°C to + 70°C | 3.0-3.6V | 3.15-3.45V <sup>1</sup> | 32.768KHz | 4-16 MHz <sup>2</sup><br>8-33 MHz <sup>3</sup> |
|            |               |          |                         |           | T24-1.1245                                     |

 If accuracy of analog operations is not relevant for the particular application, AVDD range can be expanded to 3.0 - 3.6V, which would allow direct connection to VDD for the entire operating range.

2. If external clock is used as PLL input clock.

3. If external clock is used directly as 8051 core clock.

### TABLE 24-2: AC Condition of Test

| Input Rise/Fall Time            | 3 ns       |  |  |  |  |
|---------------------------------|------------|--|--|--|--|
| Output Load                     | CL = 30 pF |  |  |  |  |
| See Figure 24-1 and Figure 24-2 |            |  |  |  |  |
|                                 |            |  |  |  |  |

T24-2.1245

### TABLE 24-3: Recommended System Power-up Timing

| Symbol                             | Parameter                                            | Minimum | Units      |
|------------------------------------|------------------------------------------------------|---------|------------|
| T <sub>PU-READ</sub> <sup>1</sup>  | Power-up (Vod = Vod Min) to LPC Host Read Operation  | 10      | ms         |
| T <sub>PU-WRITE</sub> <sup>1</sup> | Power-up (VDD = VDD Min) to LPC Host Write Operation | 10      | ms         |
|                                    |                                                      |         | T24-3.1245 |

1. This parameter is measured only for initial qualification and after a design or process change that could affect this parameter.



| Parameter                     | Description             | Test Condition | Maximum |
|-------------------------------|-------------------------|----------------|---------|
| C <sub>INc</sub> <sup>1</sup> | Clock Input Capacitance | $V_{INC} = 0V$ | 12 pF   |
| CIN <sup>1</sup>              | Input Capacitance       | $V_{IN} = 0V$  | 12 pF   |
| CI/O <sup>1</sup>             | I/O Pin Capacitance     | $V_{I/O} = 0V$ | 12 pF   |
| C <sub>OUT</sub> <sup>1</sup> | Output Pin Capacitance  | $V_{OUT} = 0V$ | 12 pF   |
|                               |                         |                | T24-4.  |

### TABLE 24-4: Pin Capacitance ( $T_A = 25^{\circ}C$ ; fc = 1MHz; $V_{DD} = AVDD = 3.3V$ ; other pins open)

1. This parameter is measured only for initial qualification and after a design or process change that could affect this parameter.

### TABLE 24-5: Reliability Characteristics

| Symbol                        | Parameter      | Minimum<br>Specification | Units  | Test Method         |
|-------------------------------|----------------|--------------------------|--------|---------------------|
| N <sub>END</sub> <sup>1</sup> | Endurance      | 10,000                   | Cycles | JEDEC Standard A117 |
| T <sub>DR</sub> <sup>1</sup>  | Data Retention | 100                      | Years  | JEDEC Standard A103 |
| I <sub>LTH</sub> 1            | Latch Up       | 100 + I <sub>DD</sub>    | mA     | JEDEC Standard 78   |

T24-5.1245

1. This parameter is measured only for initial qualification and after a design or process change that could affect this parameter.

# 24.3 DC Electrical Characteristics

| Symbol          | Type <sup>2</sup> | Parameter             | Min | Тур | Max | Unit | Test Conditions                                                     |
|-----------------|-------------------|-----------------------|-----|-----|-----|------|---------------------------------------------------------------------|
| VIL             | AIO4              | Input Low Voltage     | -   | -   | 0.8 | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Min              |
| V <sub>IH</sub> |                   | Input High Voltage    | 2.0 | -   | -   | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max              |
| IIL             |                   | Input Leakage Current | -10 |     | 10  | μΑ   | $V_{IN} = GND \text{ to } V_{DD},$<br>$V_{DD} = V_{DD} \text{ Max}$ |
| V <sub>OL</sub> |                   | Output Low Voltage    | -   | -   | 0.4 | V    | I <sub>OL</sub> =4mA                                                |
| V <sub>OH</sub> |                   | Output High Voltage   | 2.4 | -   | -   | V    | I <sub>OH</sub> =-4mA                                               |
| VIL             | I                 | Input Low Voltage     | -   | -   | 0.8 | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Min              |
| V <sub>IH</sub> |                   | Input High Voltage    | 2.0 | -   | -   | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max              |
| IIL             |                   | Input Leakage Current | -10 |     | 10  | μΑ   | $V_{IN} = GND \text{ to } V_{DD},$<br>$V_{DD} = V_{DD} \text{ Max}$ |
| V <sub>IL</sub> | I_PD              | Input Low Voltage     | -   | -   | 0.8 | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Min              |
| V <sub>IH</sub> |                   | Input High Voltage    | 2.0 | -   | -   | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max              |
| Ι <sub>ΙL</sub> |                   | Input Leakage Current | 10  | 66  | 110 | μΑ   | $V_{IN} = GND \text{ to } V_{DD},$<br>$V_{DD} = V_{DD} \text{ Max}$ |
| V <sub>IL</sub> | IO5               | Input Low Voltage     | -   | -   | 0.8 | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Min              |
| V <sub>IH</sub> |                   | Input High Voltage    | 2.0 | -   | -   | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max              |
| Ι <sub>ΙL</sub> |                   | Input Leakage Current | -10 |     | 10  | μΑ   | $V_{IN} = GND \text{ to } V_{DD},$<br>$V_{DD} = V_{DD} \text{ Max}$ |
| V <sub>OL</sub> |                   | Output Low Voltage    | -   | -   | 0.4 | V    | I <sub>OL</sub> =5mA                                                |
| V <sub>OH</sub> |                   | Output High Voltage   | 2.4 | -   | -   | V    | I <sub>OH</sub> =-5mA                                               |

### TABLE 24-6: DC Characteristics (TA=0 to 70°C, AVDD = VDD = 3.0 to 3.6V, AVSS = VSS = 0V) (1 of 3)



| Symbol           | Type <sup>2</sup> | Parameter                                                              | Min                | Тур | Мах                  | Unit | Test Conditions                                                     |
|------------------|-------------------|------------------------------------------------------------------------|--------------------|-----|----------------------|------|---------------------------------------------------------------------|
| V <sub>IL</sub>  | IOD4              | Input Low Voltage                                                      | -                  | -   | 0.8                  | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Min              |
| VIH              |                   | Input High Voltage                                                     | 2.0                | -   | -                    | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max              |
| Ι <sub>ΙL</sub>  |                   | Input Leakage Current                                                  | -10                |     | 10                   | μA   | $V_{IN} = GND \text{ to } V_{DD},$<br>$V_{DD} = V_{DD} \text{ Max}$ |
| V <sub>OL</sub>  |                   | Output Low Voltage                                                     | -                  | -   | 0.4                  | V    | I <sub>OL</sub> =4mA                                                |
| V <sub>IL</sub>  | IOD5              | Input Low Voltage                                                      | -                  | -   | 0.8                  | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Min              |
| V <sub>IH</sub>  |                   | Input High Voltage                                                     | 2.0                | -   | -                    |      | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max              |
| IIL              |                   | Input Leakage Current                                                  | -10                |     | 10                   | μA   | $V_{IN} = GND \text{ to } V_{DD},$<br>$V_{DD}=V_{DD} \text{ Max}$   |
| V <sub>OL</sub>  |                   | Output Low Voltage                                                     | -                  | -   | 0.4                  |      | I <sub>OL</sub> =5mA                                                |
| VIL              | IODPCI            | Input Low Voltage                                                      | -0.5               |     | 0.3 V <sub>DD</sub>  | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Min              |
| VIH              |                   | Input High Voltage                                                     | $0.5 V_{DD}$       |     | V <sub>DD</sub> +0.5 | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max              |
| IIL              |                   | Input Leakage Current                                                  | -10                |     | 10                   | μA   | $V_{IN} = GND$ to $V_{DD}$ ,<br>$V_{DD}=V_{DD}$ Max                 |
| V <sub>OL</sub>  |                   | Output Low Voltage                                                     | -                  | -   | 0.1V <sub>DD</sub>   |      | lout=1.5mA                                                          |
| VIL              | IOPCI             | Input Low Voltage                                                      | -0.5               |     | 0.3 V <sub>DD</sub>  | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Min              |
| VIH              |                   | Input High Voltage                                                     | $0.5 V_{DD}$       |     | V <sub>DD</sub> +0.5 | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max              |
| IIL              |                   | Input Leakage Current                                                  | -10                |     | 10                   | μA   | $V_{IN} = GND \text{ to } V_{DD},$<br>$V_{DD}=V_{DD} \text{ Max}$   |
| V <sub>OL</sub>  |                   | Output Low Voltage                                                     | -                  | -   | 0.1V <sub>DD</sub>   |      | lout=1.5mA                                                          |
| V <sub>OH</sub>  |                   | Output High Voltage                                                    | 0.9V <sub>DD</sub> | -   | -                    | V    | lout=-0.5mA                                                         |
| VIL              | IPCI              | Input Low Voltage                                                      | -0.5               |     | 0.3 V <sub>DD</sub>  | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Min              |
| VIH              |                   | Input High Voltage                                                     | $0.5 V_{DD}$       |     | V <sub>DD</sub> +0.5 | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max              |
| IIL              |                   | Input Leakage Current                                                  | -10                |     | 10                   | μA   | $V_{IN} = GND \text{ to } V_{DD},$<br>$V_{DD}=V_{DD} \text{ Max}$   |
| V <sub>OL</sub>  | OD4               | Output Low Voltage                                                     | -                  | -   | 0.4                  | V    | I <sub>OL</sub> =4mA                                                |
| VT               | SIO4_PU           | Switching threshold                                                    |                    | 1.4 |                      | V    |                                                                     |
| V <sub>T-</sub>  |                   | Schmitt trigger, negative-<br>going threshold                          | 0.8                |     |                      | V    | $AV_{DD}=V_{DD}=V_{DD}$ Min                                         |
| $V_{T+}$         |                   | Schmitt trigger, positive-going threshold                              |                    |     | 2.0                  | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max              |
| lı∟              |                   | Input Leakage Current<br>with pull-up disabled<br>with pull-up enabled | -10<br>-110        | -66 | 10<br>-10            | μA   | $V_{IN} = GND \text{ to } V_{DD},$<br>$V_{DD} = V_{DD} \text{ Max}$ |
| V <sub>OL</sub>  |                   | Output Low Voltage                                                     | -                  | -   | 0.4                  | V    | I <sub>OL</sub> =4mA                                                |
| V <sub>OH</sub>  |                   | Output High Voltage                                                    | 2.4                | -   | -                    | V    | I <sub>OH</sub> =-4mA                                               |
| V <sub>T</sub>   | SIO5              | Switching threshold                                                    |                    | 1.4 |                      | V    |                                                                     |
| V <sub>T</sub> - |                   | Schmitt trigger, negative-<br>going threshold                          | 0.8                |     |                      | V    | $AV_{DD}=V_{DD}=V_{DD}$ Min                                         |
| $V_{T+}$         |                   | Schmitt trigger, positive-going threshold                              |                    |     | 2.0                  | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max              |
| IIL              |                   | Input Leakage Current                                                  | -10                |     | 10                   | μA   | $V_{IN} = GND \text{ to } V_{DD},$<br>$V_{DD} = V_{DD} \text{ Max}$ |
| V <sub>OL</sub>  |                   | Output Low Voltage                                                     | -                  | -   | 0.4                  | V    | I <sub>OL</sub> =5mA                                                |
| V <sub>OH</sub>  |                   | Output High Voltage                                                    | 2.4                | -   | -                    | V    | I <sub>OH</sub> =-5mA                                               |

# TABLE 24-6: DC Characteristics (TA=0 to 70°C, AVDD = VDD = 3.0 to 3.6V, AVSS = VSS = 0V) (2 of 3)



| Symbol           | Type <sup>2</sup> | Parameter                                           | Min                   | Тур | Мах                   | Unit | Test Conditions                                                                                                                                                         |
|------------------|-------------------|-----------------------------------------------------|-----------------------|-----|-----------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>T</sub>   | SIOD15            | Switching threshold                                 |                       | 1.4 |                       | V    |                                                                                                                                                                         |
| V <sub>T</sub> . |                   | Schmitt trigger, negative-<br>going threshold       | 0.8                   |     |                       | V    | $AV_{DD}=V_{DD}=V_{DD}$ Min                                                                                                                                             |
| V <sub>T+</sub>  |                   | Schmitt trigger, positive-going threshold           |                       |     | 2.0                   | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max                                                                                                                  |
| Ι <sub>ΙL</sub>  |                   | Input Leakage Current                               | -10                   |     | 10                    | μA   | $V_{IN} = GND$ to $V_{DD}$ ,<br>$V_{DD}=V_{DD}$ Max                                                                                                                     |
| V <sub>OL</sub>  |                   | Output Low Voltage                                  | -                     | -   | 0.4                   | V    | I <sub>OL</sub> =15mA                                                                                                                                                   |
| V <sub>T</sub>   | SI_PU             | Switching threshold                                 |                       | 1.4 |                       | V    |                                                                                                                                                                         |
| V <sub>T+</sub>  |                   | Schmitt trigger, positive-going threshold           |                       |     | 2.0                   | V    | $AV_{DD}=V_{DD}=V_{DD}$ Min                                                                                                                                             |
| V <sub>T</sub> - |                   | Schmitt trigger, negative-<br>going threshold       | 0.8                   |     |                       | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max                                                                                                                  |
| Ι <sub>ΙL</sub>  |                   | Input Leakage Current                               | -110                  | -66 | -10                   | μΑ   | $V_{IN} = GND$ to $V_{DD}$ ,<br>$V_{DD}=V_{DD}$ Max                                                                                                                     |
| V <sub>IL</sub>  | OSC <sup>1</sup>  | Input Low Voltage (OSC1)                            | V <sub>SS</sub>       | -   | 0.2 x V <sub>DD</sub> | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Min                                                                                                                  |
| V <sub>IH</sub>  |                   | Input High Voltage(OSC1)                            | 0.8 x V <sub>DD</sub> | -   | -                     | V    | AV <sub>DD</sub> =V <sub>DD</sub> =V <sub>DD</sub> Max                                                                                                                  |
| V <sub>BOD</sub> |                   | Brown-out Detection Voltage                         | 2.05                  | 2.5 | 2.85                  | V    |                                                                                                                                                                         |
| I <sub>DD</sub>  | PWR               | V <sub>DD</sub> Supply Current in                   |                       |     |                       |      | V <sub>DD</sub> = V <sub>DD</sub> Max<br>LCLK=V <sub>ILT</sub> / V <sub>IHT</sub> at                                                                                    |
|                  |                   | Active Mode without Flash program/erase operation   |                       |     | 35                    | mA   | f=33MHz<br>ECLK=V <sub>ILT</sub> / V <sub>IHT</sub> at<br>f=14.318 MHz                                                                                                  |
|                  |                   | Active Mode with Flash pro-<br>gram/erase operation |                       |     | 45                    | mA   | PLL running at<br>f=32.2155 MHz                                                                                                                                         |
|                  |                   | Idle Mode                                           |                       |     | 25                    | mA   | f=32.768 KHz<br>All outputs and inputs<br>with pull-ups or pull-<br>downs are open. All<br>other inputs = V <sub>DD</sub> .                                             |
|                  |                   | Power Down Mode                                     |                       |     | 150                   | uA   | $V_{DD} = V_{DD} Max$<br>PLL stopped. Oscillator<br>disabled. All outputs and<br>inputs with pull-ups or<br>pull-downs are open. Al<br>other inputs = V <sub>DD</sub> . |
| I <sub>DDA</sub> | PWR               | AVod Supply Current                                 |                       |     |                       |      | $AV_{DD} = AV_{DD} Max$                                                                                                                                                 |
|                  |                   | Active Mode ADC operation                           |                       |     | 4                     | mA   | ADC clock                                                                                                                                                               |
|                  |                   | Active Mode DAC operation                           |                       | 18  | 25                    | mA   | frequency = 2MHz<br>No external load on                                                                                                                                 |
|                  |                   | Standby Mode (ADC and DAC are disabled)             |                       | 30  | 70                    | uA   | DAC outputs                                                                                                                                                             |

# TABLE 24-6: DC Characteristics (TA=0 to 70°C, AVDD = VDD = 3.0 to 3.6V, AVSS = VSS = 0V) (3 of 3)

T24-6.1245

Connect crystal oscillator circuitry to oscillator input and output pins according to the schematic on Figure 5-3.
 See I/O buffer types description in Table 2-2.



# 24.4 AC Electrical Characteristics



FIGURE 24-1: AC Input/Output Reference Waveforms

**Note:** The above reference points apply to all AC measurements specified in this section unless explicitly stated otherwise. For AC condition of test and operating range see Table 24-1 and Table 24-2.



FIGURE 24-2: A Test Load Example

### 24.4.1 LPC Interface and Firmware Memory Timing

### TABLE 24-7: LPC Clock Timing Parameters

| Symbol            | Parameter                         | Min | Max | Units |
|-------------------|-----------------------------------|-----|-----|-------|
| T <sub>CYC</sub>  | LCLK Cycle Time                   | 30  |     | ns    |
| T <sub>HIGH</sub> | LCLK High Time                    | 11  |     | ns    |
| T <sub>LOW</sub>  | LCLK Low Time                     | 11  |     | ns    |
| -                 | LCLK Slew Rate (peak-<br>to-peak) | 1   | 4   | V/ns  |
| -                 | LRESET# Slew Rate                 | 50  |     | mV/ns |

T24-7.1245







| Symbol           | Parameter                                           | Min | Max | Units |
|------------------|-----------------------------------------------------|-----|-----|-------|
| T <sub>CYC</sub> | Clock Cycle Time                                    | 30  |     | ns    |
| T <sub>SU</sub>  | Data Set Up Time to<br>Clock Rising                 | 7   |     | ns    |
| T <sub>DH</sub>  | Clock Rising to Data<br>Hold Time                   | 0   |     | ns    |
| $T_{VAL}^{1}$    | Clock Rising to Data<br>Valid                       | 2   | 11  | ns    |
| T <sub>BP</sub>  | Byte Programming<br>Time                            |     | 60  | μs    |
| T <sub>SE</sub>  | Sector-Erase Time                                   |     | 60  | ms    |
| T <sub>BE</sub>  | Block-Erase Time                                    |     | 60  | ms    |
| T <sub>ES</sub>  | Erase Suspend<br>Latency Time                       |     | 20  | μs    |
| T <sub>ON</sub>  | Clock Rising to Active<br>(Float to Active Delay)   | 2   |     | ns    |
| T <sub>OFF</sub> | Clock Rising to Inactive<br>(Active to Float Delay) |     | 28  | ns    |

### TABLE 24-8: LPC Read/Write Cycle Timing Parameters

1. Minimum and maximum time have different loads. See PCI spec.

# TABLE 24-9: LPC AC Input/Output Specifications<sup>1</sup>

| Symbol               | Parameter              | Min                                            | Max                     | Units | Conditions                                             |
|----------------------|------------------------|------------------------------------------------|-------------------------|-------|--------------------------------------------------------|
| I <sub>OH</sub> (AC) | Switching Current High | -12 V <sub>DD</sub>                            |                         | mA    | $0 < V_{OUT} \leq 0.3 V_{DD}$                          |
|                      |                        | -17.1(V <sub>DD</sub> -V <sub>OUT</sub>        |                         | mA    | $0.3 V_{DD} < V_{OUT} < 0.9 V_{DD}$                    |
|                      |                        |                                                | Equation C <sup>2</sup> |       | $0.7 V_{DD} < V_{OUT} < V_{DD}$                        |
|                      | (Test Point)           |                                                | -32 V <sub>DD</sub>     | mA    | $V_{OUT} = 0.7 V_{DD}$                                 |
| I <sub>OL</sub> (AC) | Switching Current Low  | 16 V <sub>DD</sub>                             |                         | mA    | V <sub>DD</sub> >V <sub>OUT</sub> ≥0.6 V <sub>DD</sub> |
|                      |                        | 26.7 V <sub>OUT</sub>                          |                         | mA    | $0.6 V_{DD} > V_{OUT} > 0.1 V_{DD}$                    |
|                      |                        |                                                | Equation D <sup>2</sup> |       | 0.18 V <sub>DD</sub> > V <sub>OUT</sub> > 0            |
|                      | (Test Point)           | 26.7 V <sub>OUT</sub>                          | 38 V <sub>DD</sub>      | mA    | $V_{OUT} = 0.18 V_{DD}$                                |
| I <sub>CL</sub>      | Low Clamp Current      | -25+(V <sub>IN</sub> +1)/0.015                 |                         | mA    | -3 < V <sub>IN</sub> ≦-1                               |
| I <sub>CH</sub>      | High Clamp Current     | 25+(V <sub>IN</sub> -V <sub>DD</sub> -1)/0.015 |                         | mA    | $V_{DD}$ +4 > $V_{IN} \ge V_{DD}$ +1                   |
| $SLEW_R$             | Output Rise Slew Rate  | 1                                              | 4                       | V/ns  | 0.2 V <sub>DD</sub> -0.6 V <sub>DD</sub> load          |
| $SLEW_{F}^{3}$       | Output Fall Slew Rate  | 1                                              | 4                       | V/ns  | 0.6 V <sub>DD</sub> -0.2 V <sub>DD</sub> load          |

T24-9.1245

1. This parameter is measured only for initial qualification and after a design or process change that could affect this parameter.

2. See PCI spec

3. PCI specification output load is used





FIGURE 24-4: LPC Output Timing Parameters



FIGURE 24-5: LPC Input Timing Parameters

| <b>TABLE 24-10: LPC Interface Measurement</b> | Condition Parameters |
|-----------------------------------------------|----------------------|
|-----------------------------------------------|----------------------|

| Symbol                        | Value               | Units |
|-------------------------------|---------------------|-------|
| V <sub>TH</sub> <sup>1</sup>  | 0.6 V <sub>DD</sub> | V     |
| V <sub>TL</sub> <sup>1</sup>  | 0.2 V <sub>DD</sub> | V     |
| V <sub>TEST</sub>             | 0.4 V <sub>DD</sub> | V     |
| V <sub>MAX</sub> <sup>1</sup> | 0.4 V <sub>DD</sub> | V     |
| Input Signal Edge Rate        | 1                   | V/ns  |

T24-10.1245

1. The input test environment is done with 0.1 VDD of overdrive over VIH and VIL. Timing parameters must be met with no more overdrive than this. VMAX specified the maximum peak-to-peak waveform allowed for measuring input timing. Production testing may use different voltage values, but must correlate results back to these parameters.



### TABLE 24-11: LPC Reset Timing Parameters<sup>1</sup>

| Symbol                          | Parameter                                                                                           | Min | Max | Units |
|---------------------------------|-----------------------------------------------------------------------------------------------------|-----|-----|-------|
| T <sub>LRSTP</sub>              | LRESET# Pulse Width                                                                                 | 100 |     | ns    |
| T <sub>LRSTF</sub>              | LRESET# Low to Output Float                                                                         |     | 48  | ns    |
| T <sub>LRSTD</sub> <sup>2</sup> | LRESET# High to LFRAME# or<br>SERIRQ Low (1 <sup>st</sup> LPC Host access<br>delay after LPC Reset) | 150 |     | ns    |
| T <sub>LRSTE</sub> <sup>3</sup> | LRESET# Low to LFRAME# Low if<br>reset during Sector-/Block-Erase or<br>Program                     | 60  |     | μs    |

Guaranteed by design
 LPC Reset NOT during Program or Erase operation
 LPC Reset during Program or Erase operation



FIGURE 24-6: LPC Reset Timing Diagram



### 24.4.2 External Clocks and Reset Timing

### TABLE 24-12: External Clocks and Reset Timing Parameters<sup>1</sup>

| SYMBOL                                  | PARAMETER                                                                                                 | Min | Тур    | Мах                                            | Units    |
|-----------------------------------------|-----------------------------------------------------------------------------------------------------------|-----|--------|------------------------------------------------|----------|
| $F_{OSC} = 1/T_{OSC}$                   | Crystal Oscillator Frequency                                                                              |     | 32.768 |                                                | KHz      |
| T <sub>OSCSU</sub>                      | Crystal Oscillator Start Up time                                                                          |     | 1      | 5                                              | s        |
| $1/T_{ECLK} = F_{ECLK} = F_{CCLK}$      | External Clock Frequency if used as 8051 clock                                                            | 8   |        | 33                                             | MHz      |
| $1/T_{ECLK} = F_{ECLK} = F_{PLLI}$      | External Clock Frequency if used as PLL input                                                             | 4   |        | 16                                             | MHz      |
| T <sub>ECLKH</sub> /T <sub>ECLK</sub>   | External Clock Duty Cycle                                                                                 | 40  |        | 60                                             | %        |
| T <sub>ECLKF</sub>                      | External Clock Fall Time                                                                                  |     |        | 5                                              | ns       |
| T <sub>ECLKR</sub>                      | External Clock Rise Time                                                                                  |     |        | 5                                              | ns       |
| F <sub>RCLK</sub>                       | Ring Oscillator Frequency                                                                                 | 8   |        | 24                                             | MHz      |
| T <sub>PLLON</sub>                      | Time to switch 8051 core clock to PLL output                                                              |     |        | 300 + 16128/<br>F <sub>PLLO</sub> <sup>2</sup> | μs       |
| T <sub>CCLK</sub>                       | 8051 Core Clock Period requirements                                                                       | 30  |        | 125                                            | ns       |
| T <sub>WLOW</sub> (T <sub>WHIGH</sub> ) | External interrupt input pulse low (high) time                                                            | 2   |        |                                                | TCCLK    |
| T <sub>WLOW</sub> (T <sub>WHIGH</sub> ) | External timer input pulse low (high) time                                                                | 12  |        |                                                | TCCLK    |
| T <sub>XRSTP</sub>                      | External Reset# pulse width                                                                               | 48  |        |                                                | TCCLK    |
| T <sub>XRSTD</sub>                      | External Reset# to 1 <sup>st</sup> LPC Host access delay<br>External Reset# High to 8051 code start delay | 10  |        | 10                                             | ms<br>ms |
| T <sub>PURSTD</sub>                     | Power-up to 1 <sup>st</sup> LPC Host access delay<br>Power-up to 8051 code start delay                    | 10  |        | 10                                             | ms<br>ms |

T24-12.1245

1. Guaranteed by design

2. FPLLO – PLL output clock frequency in MHz (see Section 5.3.2)







### FIGURE 24-8: External Interrupt Timing Diagram





FIGURE 24-9: Power Up and External Reset Timing Diagram

# 24.4.3 SMBus Interface Timing



FIGURE 24-10: SMBus Timing Diagram

| <b>TABLE 24-13: SMBus Interface Timing Paramete</b> |
|-----------------------------------------------------|
|-----------------------------------------------------|

| SMBus Operating Frequency                                                                   |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                         |
|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| chibde operating riequency                                                                  |                                                                                                                                                                                                                                                  | 100                                                                                                                                                                                                                                                                        | kHz                                                                                                                                                                                                                                                                     |
| Bus Free Time Between Stop and Start Condi-<br>tion                                         | 4.7                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                            | μs                                                                                                                                                                                                                                                                      |
| Hold time after (repeated) Start Condition. After this period, the first clock is generated |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                            | μs                                                                                                                                                                                                                                                                      |
| Repeated Start Condition setup time                                                         | 4.7                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                            | μs                                                                                                                                                                                                                                                                      |
| Stop Condition Setup Time                                                                   | 4.0                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                            | μs                                                                                                                                                                                                                                                                      |
| Data Hold Time                                                                              | 90                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                            | ns                                                                                                                                                                                                                                                                      |
| Data Setup Time                                                                             | 250                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                            | ns                                                                                                                                                                                                                                                                      |
| Clock Low Period                                                                            | 4.7                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                            | μs                                                                                                                                                                                                                                                                      |
| Clock High Period                                                                           | 4.0                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                            | μs                                                                                                                                                                                                                                                                      |
| Clock/Data Fall Time                                                                        |                                                                                                                                                                                                                                                  | 300                                                                                                                                                                                                                                                                        | ns                                                                                                                                                                                                                                                                      |
| Clock/Data Rise Time                                                                        |                                                                                                                                                                                                                                                  | 1000                                                                                                                                                                                                                                                                       | ns                                                                                                                                                                                                                                                                      |
|                                                                                             | tionHold time after (repeated) Start Condition. After<br>this period, the first clock is generatedRepeated Start Condition setup timeStop Condition Setup TimeData Hold TimeData Setup TimeClock Low PeriodClock High PeriodClock/Data Fall Time | tion4.0Hold time after (repeated) Start Condition. After<br>this period, the first clock is generated4.0Repeated Start Condition setup time4.7Stop Condition Setup Time4.0Data Hold Time90Data Setup Time250Clock Low Period4.7Clock High Period4.0Clock/Data Fall Time4.0 | tionHold time after (repeated) Start Condition. After<br>this period, the first clock is generated4.0Repeated Start Condition setup time4.7Stop Condition Setup Time4.0Data Hold Time90Data Setup Time250Clock Low Period4.7Clock High Period4.0Clock/Data Fall Time300 |

1. Guaranteed by design

2. Depends on pull-up value



### TABLE 24-14: SMBus Interface Measurement Reference Points

| Symbol | Value           | Units       |
|--------|-----------------|-------------|
| Vтн    | V⊤+ Max + 0.25V | V           |
| Vtl    | V⊤- Min - 0.15V | V           |
|        |                 | T24-14.1245 |

24.4.4 PS/2 Interface Timing



# FIGURE 24-11: PS/2 Hardware State Machine Receive Timing Diagram

Note: Solid (dashed) line indicates that PS/2 interface signal is driven by SST79LF008 (PS/2 peripheral device).



### FIGURE 24-12: PS/2 Hardware State Machine Transmit Timing Diagram

Note: Solid (dashed) line indicates that PS/2 interface signal is driven by SST79LF008 (PS/2 peripheral device).



### TABLE 24-15: PS/2 Receive Timing Parameters<sup>1</sup>

| Symbol | Parameter                                                                                                                                                             | Min | Max              | Units |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------------|-------|
| T1     | Time from PS/2 state machine enabled in receive mode (PS2CRn_PS2_EN = 1 and PS2CRn_PS2_T/R = 0) to SST79LF008 PSCLK and PSDAT outputs are in High-Z state             | 6   | 15               | ns    |
| T2     | PSCLK period                                                                                                                                                          |     | 300 <sup>2</sup> | μs    |
| Т3     | Duration of PSCLK active (high)                                                                                                                                       | 30  |                  | μs    |
| T4     | Duration of PSCLK inactive (low)                                                                                                                                      | 30  |                  | μs    |
| Т5     | Setup time from input PSDAT transition to falling edge of PSCLK (SST79LF008 uses fall-<br>ing edge of PSCLK to sample PSDAT)                                          | 0   |                  | ns    |
| Т6     | Hold time from falling edge of PSCLK to input PSDAT transition (SST79LF008 uses falling edge of PSCLK to sample PSDAT)                                                | 600 |                  | ns    |
| T7     | Time from falling edge of the 1st clock (Start bit) to falling edge of the 11th clock (Stop bit)                                                                      |     | 2 <sup>2</sup>   | ms    |
| Т8     | Time from falling edge of the 11th clock (Stop bit) to SST79LF008 sets<br>PS2STSn_RDATA_RDY bit and drives PSCLK low to inhibit the next transfer                     |     | 600              | ns    |
| Т9     | Time from SST79LF008 Status Register read (trailing edge of the read signal) to PS2STSn_RDATA_RDY bit cleared                                                         |     | 0                | ns    |
| T10    | Time from SST79LF008 Status Register read (trailing edge of the read signal) to SST79LF008 PSCLK output is in High-Z state                                            | 30  | 150              | ns    |
| T11    | Time from PS/2 state machine disabled (PS2CRn_PS2_EN = 0) to SST79LF008 PSCLK and PSDAT outputs are configured according to the PS2CRn_WR_CLK and PS2CRn_WR_DATA bits | 6   | 15               | ns    |
| T12    | Time from PS2STSn_RDATA_RDY bit low-to-high transition to PS/2 Channel interrupt generated                                                                            |     | 150              | ns    |
| T13    | Time from SST79LF008 Status Register read (trailing edge of the read signal) to PS/2 interrupt cleared                                                                |     | 0                | ns    |

T24-15.1320

1. Guaranteed by design

2. These maximum limits applied by SST79LF008 hardware provided the respective time-out detection is enabled



### TABLE 24-16: PS/2 Transmit Timing Parameters<sup>1</sup>

| Symbol | Parameter                                                                                                                                                                                              | Min    | Max              | Unite    |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------|----------|
| T1     | Time from PS/2 state machine enabled in receive mode<br>(PS2CRn_PS2_EN = 1 and PS2CRn_PS2_T/R = 0) to SST79LF008<br>PSCLK and PSDAT outputs are in High-Z state                                        | 6      | 15               | ns       |
| T2     | Time from PS/2 state machine switched into transmit mode (PS2CRn_PS2_T/R = 1) to PSCLK line driven low                                                                                                 | 60     | 300              | ns       |
| Т3     | Time from SST79LF008 transmit register write (trailing edge of the write signal) to PS2STSn_XMIT_IDLE bit cleared                                                                                      |        | T5 + 0           | ns       |
| T4     | Time from SST79LF008 transmit register write (trailing edge of the write signal) to PSDAT line driven low                                                                                              | 30     | 150              | ns       |
| T5     | Time from SST79LF008 transmit register write (trailing edge of the write signal) to SST79LF008 PSCLK output is in High-Z state                                                                         | T4+ 90 | T4+ 450          | ns       |
| T6     | Time from request-to-send state (PSCLK = 1, PSDAT = 0) to the $1^{st}$ clock falling edge (Start bit) generated by the peripheral device                                                               | 2      | 25 <sup>2</sup>  | μs<br>ms |
| T7     | PSCLK period                                                                                                                                                                                           |        | 300 <sup>2</sup> | μs       |
| T8     | Duration of PSCLK active (high)                                                                                                                                                                        | 30     |                  | μs       |
| Т9     | Duration of PSCLK inactive (low)                                                                                                                                                                       | 30     |                  | μs       |
| T10    | Time from falling edge of the1st clock (Start bit) to rising edge of the 11th clock (Line Control bit)                                                                                                 |        | 2 <sup>2</sup>   | ms       |
| T11    | Time from falling edge of PSCLK to SST79LF008 PSDATA output is in<br>High-Z state to transmit '1', or driven low to transmit '0' (the peripheral<br>device uses rising edge of PSCLK to sample PSDATA) | 60     | 450              | ns       |
| T12    | Time from rising edge of the 11th clock (Line Control bit) to PS_T/R bit cleared                                                                                                                       | 90     | 450              | ns       |
| T13    | Time from PS_T/R bit cleared to PS2STSn_XMIT_IDLE bit set                                                                                                                                              | 30     | 150              | ns       |
| T14    | Time from rising edge of the 10 <sup>th</sup> clock (Stop bit) to SST79LF008 PSDATA output is in High-Z state                                                                                          | 30     | 600              | ns       |
| T15    | Time from PS2STSn_XMIT_IDLE bit low-to-high transition to PS/2 Channel interrupt generated Interrupt is cleared by reading the Status Register same as in receive mode - not shown.                    | 30     | 150              | ns       |
| T16    | Time from PS/2 state machine disabled (PS2CRn_PS2_EN = 0) to<br>SST79LF008 PSCLK and PSDAT outputs are configured according to the<br>PS2CRn_WR_CLK and PS2CRn_WR_DATA bits                            | 6      | 15               | ns       |

T24-16.1245

1. Guaranteed by design

2. These maximum limits applied by SST79LF008 hardware provided the respective time-out detection is enabled

### TABLE 24-17: PS/2 Interrupt Timing in bit-banging mode<sup>1,2</sup>

| Symbol | Parameter                                                                                              | Min | Max | Units |
|--------|--------------------------------------------------------------------------------------------------------|-----|-----|-------|
| T1     | Time from falling edge of PSCLK to PS/2 Channel Interrupt generated                                    | 60  | 450 | ns    |
| T2     | Time from SST79LF008 Status Register read (trailing edge of the read signal) to PS/2 interrupt cleared |     | 0   | ns    |

T24-17.1245

1. In bit-banging mode PS/2 receive and transmit protocols are controlled by the 8051 firmware

2. Guaranteed by design





### FIGURE 24-13: PS/2 Interrupt Timing in bit-banging mode

### TABLE 24-18: PS/2 Interface Measurement Reference Points

| Symbol          | Value                | Units |
|-----------------|----------------------|-------|
| VTH             | V <sub>T+</sub> Max  | V     |
| V <sub>TL</sub> | V <sub>T</sub> - Min | V     |

T24-18.1245

### 24.4.5 UART Timing



FIGURE 24-14: UART Timing Diagram (Shift Register Mode)



# TABLE 24-19: UART Timing Parameters<sup>1</sup>

|                   |                                               |     | 8051 core clock frequency |       |     |                                         |                                         |             |
|-------------------|-----------------------------------------------|-----|---------------------------|-------|-----|-----------------------------------------|-----------------------------------------|-------------|
|                   |                                               | 12  | MHz                       | 32MHz |     | Variable                                |                                         |             |
| Symbol            | Parameter                                     | Min | Max                       | Min   | Max | Min                                     | Мах                                     | Units       |
| T <sub>XLXL</sub> | Serial Port Clock Cycle Time                  | 1.0 |                           | 0.375 |     | 12 T <sub>CCLK</sub> <sup>2</sup>       |                                         | us          |
| T <sub>QVXH</sub> | Output Data Setup to Clock Rising Edge        | 700 |                           | 179   |     | 10 Т <sub>ССLК</sub> <sup>2</sup> – 133 |                                         | ns          |
| T <sub>XHQX</sub> | Output Data Hold After Clock Ris-<br>ing Edge | 50  |                           | 0     |     | 2 T <sub>CCLK</sub> <sup>2</sup> – 117  |                                         | ns          |
| $T_{XHDXr}$       | Input data Hold After Clock Rising<br>Edge    | 0   |                           | 0     |     | 0                                       |                                         | ns          |
| $T_{XHDV}$        | Clock Rising Edge to input Data<br>Valid      |     | 700                       |       | 179 |                                         | 10 Т <sub>ССLК</sub> <sup>2</sup> - 133 | ns          |
|                   |                                               | •   |                           | •     | •   | •                                       | •                                       | T24-19.1245 |

Guaranteed by design
 T<sub>CCLK</sub> – 8051core clock period (see Table 24-12)

### 24.4.6 SPI Timing

# TABLE 24-20: SPI Timing Parameters<sup>1</sup>

| Symbol            | Parameter                                 | Min   | Max | Units                          |
|-------------------|-------------------------------------------|-------|-----|--------------------------------|
| T <sub>SU</sub>   | Data In Setup time                        | 1     |     | T <sub>CCLK</sub> <sup>2</sup> |
| T <sub>DH</sub>   | Data In Hold time                         | 1     |     | T <sub>CCLK</sub> <sup>2</sup> |
| Tv                | Data Out Valid time                       |       | 1   | T <sub>CCLK</sub> <sup>2</sup> |
| T <sub>SSS</sub>  | SS setup time.                            | 1     |     | T <sub>CCLK</sub> <sup>2</sup> |
| T <sub>SSH</sub>  | SS hold time                              | 1     |     | T <sub>CCLK</sub> <sup>2</sup> |
| Т <sub>SCK</sub>  | Serial Clock cycle in master (slave) mode | 2 (4) |     | T <sub>CCLK</sub> <sup>2</sup> |
| Т <sub>SCKH</sub> | Serial Clock low time                     | 1     |     | T <sub>CCLK</sub> <sup>2</sup> |
| Т <sub>SCK</sub>  | Serial Clock high time                    | 1     |     | T <sub>CCLK</sub> <sup>2</sup> |
|                   | ·                                         |       | •   | T24-20.12                      |

1. Guaranteed by design

2. TCCLK - 8051core clock period (see Table 24-12)





FIGURE 24-15: SPI Master Timing Diagram (CPHA=0, MSTR = 1)



FIGURE 24-16: SPI Master Timing Diagram (CPHA=1, MSTR = 1)

245





FIGURE 24-17: SPI Slave Timing Diagram (CPHA=0, MSTR = 0)



FIGURE 24-18: SPI Slave Timing Diagram (CPHA=1, MSTR = 0)



### 24.4.7 PWM and FAN Tachometer Timing



FIGURE 24-19: PWM Output Signals Timing Diagram

### TABLE 24-21: PWM Output Timing Parameters<sup>1</sup>

| Symbol            | Parameter             | Min | Мах | Units                          |
|-------------------|-----------------------|-----|-----|--------------------------------|
| T <sub>PWMV</sub> | PWM Output Valid Time | 0   | 0.5 | T <sub>CCLK</sub> <sup>2</sup> |
|                   |                       |     |     | T24-21.1245                    |

1. Guaranteed by design

2. T<sub>CCLK</sub> – 8051core clock period (see Table 24-12)





### FIGURE 24-20: FAN Tachometer Input Timing Diagram

### TABLE 24-22: FAN Tachometer Input Timing Parameters<sup>1</sup>

| Symbol          | Parameter                            | Min | Max | Units                           |
|-----------------|--------------------------------------|-----|-----|---------------------------------|
| $T_{FW}$        | Fan Tachometer Input Pulse Width     | 4   |     | T <sub>FTCLK</sub> <sup>2</sup> |
| T <sub>FH</sub> | Fan Tachometer Input Pulse High Time | 3   |     | T <sub>FTCLK</sub> <sup>2</sup> |
| T <sub>FL</sub> | Fan Tachometer Input Pulse Low Time  | 1   |     | T <sub>FTCLK</sub> <sup>2</sup> |
|                 |                                      | •   |     | T24-22.1245                     |

1. Guaranteed by design 2.  $T_{FTCLK}$  is a period of the clock used for the tachometer counter (see Section 5.2)

### 24.4.8 aLPC Interface Timing



FIGURE 24-21: aLPC Timing Diagram

### TABLE 24-23: aLPC Timing Parameters<sup>1</sup>

| Symbol              | Parameter                                                                                                         | MIN                             | MAX | UNITS |
|---------------------|-------------------------------------------------------------------------------------------------------------------|---------------------------------|-----|-------|
| T <sub>ALCLK</sub>  | aLCLK Clock Cycle Time before entry to the aLPC mode <sup>2</sup>                                                 | 1250                            |     | ns    |
| T <sub>ALCLK</sub>  | aLCLK Clock Cycle Time in the aLPC mode <sup>3</sup>                                                              | 200                             |     | ns    |
| T <sub>ALCLKH</sub> | aLCLK Clock High Time                                                                                             | 80                              |     | ns    |
| T <sub>ACLKL</sub>  | aLCLK Clock Low Time                                                                                              | 80                              |     | ns    |
| T <sub>HLD</sub>    | Clock Rising to Output Data Hold                                                                                  | 0                               |     | ns    |
| T <sub>VALD</sub>   | Clock Rising to Output Data Valid                                                                                 | 2                               | 20  | ns    |
| T <sub>VALF</sub>   | Clock Falling to Output aLFARME Valid                                                                             | 5                               | 20  | ns    |
| T <sub>SU</sub>     | Input Data Set Up Time to Clock Falling                                                                           | 10                              |     | ns    |
| T <sub>DH</sub>     | Clock Falling to Input Data Hold Time                                                                             | 5                               |     | ns    |
| T <sub>ARSTD</sub>  | aLPC mode entry to 1 <sup>st</sup> aLPC Host access delay aLPC mode exit to 1 <sup>st</sup> LPC Host access delay | 15000 +<br>8*T <sub>ALCLK</sub> |     | ns    |

Guaranteed by design
 During Enable\_and\_Poll and Switch\_and\_Reset sequences followed by reset completion delay T<sub>ARSTD</sub>
 After T<sub>ARSTD</sub> delay

T24-23.1245



T24-24.1245

Advance Information

# 24.5 Analog Characteristics

### 24.5.1 ADC Characteristics

### TABLE 24-24: ADC Characteristics (TA=0 to 70°C, VDD = 3.0-3.6V, AVDD = 3.15-3.45V, AVSS = VSS = 0V)

| Symbol                        | Parameter                             | Min | Тур  | Мах  | Units | Conditions                    |
|-------------------------------|---------------------------------------|-----|------|------|-------|-------------------------------|
| Bit                           | Resolution                            |     | 10   |      | Bits  |                               |
| AINT <sup>1</sup>             | Analog Input Voltage                  | 0   |      | AVdd | V     |                               |
| DNL                           | Differential Non-Lin-<br>earity Error |     | ±0.8 | ±1   | LSB   |                               |
| INL                           | Integral Non-Linearity<br>Error       |     | ±1.0 | ±2   | LSB   |                               |
| TOPOFF<br>BOTOFF <sup>1</sup> | Offset Voltage                        | -8  | 3    | 8    | LSB   |                               |
| F <sub>C</sub>                | Maximum Conversion<br>Rate            |     |      | 400  | KSPS  | ADC clock frequency = 2.0 MHz |

1. Guaranteed by design

### 24.5.2 DAC Characteristics

### TABLE 24-25: DAC Characteristics (TA=0 to 70°C, VDD = 3.0-3.6V, AVDD = 3.15-3.45V, AVSS = VSS = 0V, RL >= 100k, CL <= 50pF)

| Symbol                                                            | Parameter                             | Min   | Тур   | Max      | Units | Conditions                    | Comments                                                                                |
|-------------------------------------------------------------------|---------------------------------------|-------|-------|----------|-------|-------------------------------|-----------------------------------------------------------------------------------------|
| Bit                                                               | Resolution                            |       | 8     |          | Bits  |                               |                                                                                         |
| DNL                                                               | Differential Non-Lin-<br>earity Error |       | 0.3   | 1.0      | LSB   |                               |                                                                                         |
| INL                                                               | Integral Non-Linearity<br>Error       |       | 0.5   | 1.0      | LSB   |                               |                                                                                         |
| $V_{FS}$                                                          | Full Scale Voltage                    | 3.087 | 3.207 | 3.287    | V     | $AV_{DD} = 3.3V$              | $V_{FS} = V_{OMAX} - VOUT(00H)^1$                                                       |
| $V_{ZSE}$                                                         | Zero Scale Error                      |       | 40    | 100      | mV    |                               | $V_{ZSE} = VOUT(00H)^1$                                                                 |
| $V_{FSE}$                                                         | Full Scale Voltage<br>Error           |       | 40    | 100      | mV    |                               | V <sub>FSE</sub> =<br>V <sub>OMAX</sub> – (AV <sub>DD</sub> *255/256)                   |
| V <sub>OMAX</sub> <sup>2</sup>                                    | Maximum Output Volt-<br>age           | 3.187 | 3.247 | 3.287    | V     | $AV_{DD} = 3.3V$              | V <sub>OMAX</sub> = VOUT(FFH)                                                           |
| $V_{LSB}^2$                                                       | LSB Size                              | 12.11 | 12.58 | 12.89    | mV    | $AV_{DD} = 3.3V$              | $V_{LSB} = (V_{OMAX} - VOUT(00H)^{1})/255$                                              |
|                                                                   | Channel Crosstalk <sup>2,3</sup>      |       | -40   | -30      | dB    |                               | 20*log(V <sub>PP</sub> max of unselected channel / V <sub>FS</sub> of selected channel) |
| T <sub>S</sub> <sup>2,4</sup>                                     | Analog Output Settling<br>Time        |       |       | 1        | us    | $C_{L} = 50pF$ $R_{L} = 100k$ |                                                                                         |
| T <sub>ON</sub> <sup>2,5</sup><br>T <sub>ONA</sub> <sup>2,6</sup> | Analog Output Enable<br>Time          |       |       | 3<br>100 | us    | $C_{L} = 50pF$ $R_{L} = 100k$ |                                                                                         |

T24-25.1245

1. VOUT(XXH) - actual DAC output voltage for input code XXH

2. Guaranteed by design

3. Peak-to-peak output voltage of unselected channel with input code 80H, when selected channel output voltage changes from VOUT(00H) to VOUT(FFH)

4. Time from loading data to output voltage settling within an error of +/- 0.5LSB

5. Time from the moment when DACENn = 1 in DACCTRL register to settling of the output voltage

6. Time from the moment when DACEN = 1 in DACCTRL register to settling of the output voltage



# 25.0 PRODUCT ORDERING INFORMATION



\* Environmental suffix "F" or "E" denotes non-Pb solder. SST non-Pb solder devices are "RoHS Compliant".

# 25.1 Valid Combinations

Valid combinations for SST79LF008

SST79LF008-33-C-LRRF SST79LF008-33-C-BZYE

**Note:** Valid combinations are those products in mass production or will be in mass production. Consult your SST sales representative to confirm availability of valid combinations and to determine availability of new combinations.



# 26.0 PACKAGING DIAGRAMS



FIGURE 26-1: 176-lead Low-profile Quad Flat Pack (LQFP) SST Package Code: LRR





FIGURE 26-2: 176-ball Thin-profile Fine-pitch Ball Grid Array (TFBGA) 12mm x 12mm SST Package Code: BZY

| TABLE | 26-1: | Revision | History |
|-------|-------|----------|---------|
|-------|-------|----------|---------|

| Number | Description                                                                                                                                 | Date     |  |  |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------|----------|--|--|
| 00     | Initial Release of data sheet                                                                                                               | May 2006 |  |  |
| 01     | • In Figure 2-1: Pin Assignments, modified pin description for pins B1 thru B7.                                                             | Oct 2006 |  |  |
|        | In Figure 2-2: Pin Assignments, changed 052 to 152.                                                                                         |          |  |  |
|        | • In Table 4-4: IAP Commands, changed No Operation to No Reserve in row 1, and added a new row at bottom for No Operation.                  |          |  |  |
|        | <ul> <li>For Control Register "14.4.3.3 PS/2 Control Register 2 (PS2CR2)" on<br/>page 185, edited the PS2CRn_STOP[1:0] Function.</li> </ul> |          |  |  |
|        | • In Table 24-6: DC Characteristics, revised V <sub>IL</sub> AND V <sub>IH</sub> Min. and Max vaules.                                       |          |  |  |
|        | Added paragraph (3rd) to "SPI Description" on page 159.                                                                                     |          |  |  |
|        | Revised SPI Transfer Formats, Figure 12-2 and Figure 12-3                                                                                   |          |  |  |

Silicon Storage Technology, Inc. • 1171 Sonora Court • Sunnyvale, CA 94086 • Telephone 408-735-9110 • Fax 408-735-9036 www.SuperFlash.com or www.sst.com